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I.   INTRODUCTION 

Production  rule  systems  provide  a  means  for  encoding 
"expert"  knowledge  about  some  domain  of  information  and  offer 
techniques  for  using  this  knowledge  to  provide  answers  for 
questions  in  the  domain.   A  prototype  production  rule  program, 
DECAIDS  (Decision  aids)  ,  was  developed  using  current 
Artificial  Intelligence  (AI)  methodology  in  an  effort  to 
organize  decision  aiding  characteristics  relating  to  computer 
resource  allocation  alternatives.   The  purpose  of  this 
program  is  to  provide  recommendations  during  an  interactive 
consultation  session.   During  this  session,  specific  informa- 
tion is  requested  from  the  consultation  system  user  concerning 
his  organization's  task,  technology,  environment,  and  struc- 
ture characteristics.   This  information  is  then  used  to 
invoke  system  production  rules  which  are  used  to  produce 
the  recommendations . 

While  the  primary  subjects  of  this  paper  are  the  pro- 
duction rule  system  and  a  sample  categorization  of  managerial 
decision  aids,  it  is  noteworthy  to  mention  that  several  other 
areas  of  study  are  involved.   These  include  inferential 
analysis,  organizational  theory,  predicate  calculus,  and 
decision  aid  characteristics.   The  last  section  in  this 
thesis  is  a  tutorial  containing  instructions  for  the  use  of 
the  EMYCIN  inference  engine  and  procedures  for  designing 
and  implementing  a  database  (referred  to  as  a  knowledge  base) . 


While  some  AI  systems  do  attempt  to  model  the  human 
thought  process,  this  paper  has  adopted  the  EMYCIN  inference 
engine  developed  from  Stanford  University's  MYCIN  research 
program.   This  program,  EMYCIN,  permits  problems  to  be 
solved  using  goal-directed,  backward-chaining  production 
rules.   Backward-chaining  is  a  tree  traversal  method.   It 
is  accomplished  by  searching  through  a  tree  from  a  goal, 
bottom  leaf,  state  toward  some  initial,  root  node,  state. 
The  concept  of  "spaces"  may  also  be  used  here  to  further 
explain  that  the  shape  of  the  state  space  determines  whether 
forward  or  backward-chaining  is  utilized;  fanning  in  from 
some  goal  state  to  an  initial  state  represents  backward- 
chaining  [Winston,  1977]. 

The  important  thing  in  AI  is  that  a  software  program 
produces  "behavior"  similar  to  that  which  a  human  can  produce, 
understand,  and  recognize.   Generally,  the  problems  posed  to 
AI  are  not  those  for  which  a  specific  algorithm  can  be 
written.   For  instance,  a  manager  probably  could  not  explain, 
algorithmically ,  how  he  arrived  at  a  particular  decision. 
He  uses  a  myriad  of  facts,  procedures,  and  experiences  to 
tell  him  what  to  do  during  certain  circumstances  and  these 
factors  are  used  to  produce  a  decision.   EMYCIN  was  developed 
with  the  assumption  that  a  human  would  use  the  same  data  that 
the  program  used  but  not  in  the  same  manner.   The  program 
provides  a  method  to  weigh  conflicting  information,  calcu- 
lating how  much  information  is  sufficient  to  achieve  a 
recommendation,  and  identifying  those  cases  where  insufficient 


information  is  available  to  arrive  at  an  acceptable  decision. 
This  is  what  a  human  does  when  making  a  decision.   The  AI 
program  must  therefore  parallel  these  human  processes  as 
closely  as  possible  in  order  to  produce  an  acceptable 
result  [Scott,  1979]. 

The  EMYCIN  program  is  written  in  INTERLISP.   This  computer 
language  provides  an  excellent  basis  for  an  AI  system  since 
the  information  in  the  knowledge  base  is  grouped  into  lists, 
at  the  tree  nodes,  and  these  lists  are  appropriately  manipu- 
lated by  INTERLISP  functions.   This  thesis  provides  the 
background  materials  and  concepts  required  to  design, 
implement,  and  operate  an  Artificial  Intelligence  knowledge 
based  system. 


II.   BACKGROUND 

The  first  domain  in  which  computers  have  successfully 
demonstrated  expert  performance  is  mathematical  problem 
solving.   The  speed  with  which  computers  can  solve  arith- 
metic problems  is  well  known.   The  ability  of  the  user  to 
adequately  prepare  the  program  for  a  particular  problem  is 
the  major  limiting  factor  in  computer  performance.   Pro- 
duction rule  systems  will  be  discussed  as  a  method  of 
preparation,  or  representation,  of  data  used  in  Artificial 
intelligence  programs. 

Artificial  Intelligence  (AI)  is  a  relatively  unexplored 
area  of  computer  science.   Simply  stated,  AI  is  the  study 
of  ideas  which  enable  a  computer  to  perform  in  a  manner 
that  resembles  intelligent  behavior.   The  ability  to  acquire 
and  apply  knowledge,  to  manipulate  and  communicate  ideas, 
and  the  ability  to  reason  are  all  parts  of  this  intelligent 
behavior.   A  concise  definition  of  intelligence  is  diffi- 
cult to  state  because  of  the  wide  range  of  information- 
processing  and  information-representation  concepts  involved. 
The  primary  goals  of  AI  are  to  make  computers  more  useful 
and  to  comprehend  the  principles  which  make  intelligence 
possible  [Winston,  1977,  p.  1]. 

A.   ARTIFICIAL  INTELLIGENCE  SYSTEMS 

The  field  of  Artificial  Intelligence  is  concerned  with 
producing  systems  which  operate  in  five  basic  areas.   These 


represent  basic  human  activities  and  therefore  the  supporting 
systems  are  referred  to  as  Artificial  Intelligence  [Nilson, 
1978,  p.  1-13].   The  first  of  these  areas  is  intelligent 
information  retrieval. 

Information  retrieval,  from  database  systems,  is  not  a 
new  problem  to  computer  science.   However,  when  the  asso- 
ciated system  is  designed  to  produce  inferences  or  deductions 
dependent  upon  the  information  in  the  database,  the  program 
takes  on  apparent  intelligence.   Use  of  natural  language 
(i.e.,  English)  methods  to  produce  deductions  and  storage 
of  large  amounts  of  generally  known  information  are  the 
primary  design  considerations  facing  the  system  designer. 

Expert  information,  in  the  form  of  rules,  inference 
statements,  is  interpreted  to  produce  values  for  parameters, 
which  are  the  program's  ultimate  output.   The  domain  of 
computer  resource  allocation  based  upon  organizational 
structure  is  an  example  of  an  intelligent  information 
retrieval  system  contained  in  this  paper.   Theorem  proving, 
disease  diagnosis,  mechanical  controls  (robots),  and  auto- 
mated programming  are  some  other  applications  for  AI 
[Nilsson,  1971]. 

One  of  the  problems  encountered  in  AI  is  the  requirement 
for  categorizing  into  a  manageable  form  vast  amounts  of  data. 
A  system  may  be  provided  with  sensory  equipment  which  collects 
input  data.   However,  unless  there  is  sufficient  information 
for  the  system,  for  example  a  robot,  to  test  against,  the 
interpretation  of  the  input  data  may  be  incomplete. 
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The  AI  program,  unlike  conventional  computer  programs 
which  are  highly  formatted,  will  possess  a  large  knowledge 
base  of  facts  from  which  the  attainment  of  goals  is  sought. 
The  amount  of  information  required  to  accomplish  a  given 
task  is  an  area  of  major  emphasis  to  AI  researchers.   For 
example,  the  difficulty  in  programming  robots  to  process 
sufficient  information  and  to  perform  even  simple  jobs  lies 
in  the  total  number  of  possible  combinations  of  situations 
which  may  be  encountered  and  therefore  required  to  be  stored 
in  the  knowledge  base.   Accordingly,  the  system  must  have  a 
method  for  selecting  from  among  the  knowledge  base  facts  to 
make  appropriate  inferences. 

This  paper  will  explain  a  prototype  decision  support 
program,  DECAIDS,  and  explain  the  necessary  background  and 
user  information  needed  to  use  or  expand  the  program. 

B.   ARTIFICIAL  INTELLIGENCE  LANGUAGES 

As  the  study  of  AI  has  expanded,  several  programming 
problems  have  led  to  the  search  for  new  and  more  powerful 
methods  for  representing  knowledge.   Paramount  among  these 
difficulties  has  been  the  inability  of  existing  languages 
to  deal  adequately  with  list  processing  and  symbol  manipu- 
lation.  This  fact  has  led  to  the  development  of  several 
new  programming  languages,  such  as  COMIT,  IPL,  LISP, 
INTERLISP,  and  SAIL  to  name  just  a  few  [Bobrow  and  Rafael, 
1974]  . 
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This  paper  deals  with  INTERLISP  as  used  by  the  EMYCIN/ 
DECAIDS  program.   The  EMYCIN  system  was  used  to  provide  the 
inference  engine  (inference  manipulation)  for  the  prototype 
managerial  decision  aiding  program  DECAIDS.   INTERLISP  is 
a  relatively  easy  language  to  learn  and  use  because  it  is 
constructed  of  a  simple  syntax.   It  requires  no  previous 
knowledge  of  high-level  languages  such  as  FORTRAN  or  PL/1. 
There  are  about  forty  common  functions  in  INTERLISP. 
Approximately  one-half  of  these  are  highly  mnemonic  arith- 
metic operations.   The  remaining  functions  perform  the  other 
operations  required  for  successful  list  processing  and  symbol 
manipulation  [Winston,  1977]. 

The  basic  structure  of  INTERLISP  is  the  symbolic-expression 
(S-expression)  which  is  called  a  list  of  elements.   These 
elements  may  be  numbers  or  function  names.   This  format 
of  s-expressions  can  be  readily  adapted  to  the  n-tuple 
concept  described  in  the  predicate  calculus  section  of  this 
paper.   The  following  example  has  three  elements.   (The 
parentheses  are  required  of  all  references  to  INTERLISP.) 
[Teitelman,  1974,  p.  53] . 

(PLUS  3.14  2.71) 

In  this  example,  PLUS  is  the  addition  function  standing 
before  the  two  arguments,  3.14  and  2.71,  which  are  to  be 
acted  upon.   This  example  also  demonstrates  the  prefix 
notation  which  is  used  in  INTERLISP  (i.e.,  the  function 
always  precedes  the  arguments) . 
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C.   KNOWLEDGE  BASE 

The  knowledge  base,  for  an  Artificial  Intelligence  pro- 
gram, is  the  data  base  supplied  by  an  "expert"  and  operated 
on  by  a  production  system.   This  database  is  composed  of 
an  ordered  string  or  strings  of  replacement  rules.   Design- 
ing and  implementing  a  knowledge  base  requires  the  answers 
to  some  general  problem-solving  questions: 

What  kinds  of  data  are  required?   (specific 
facts  or  ideas) ;  how  should  the  knowledge  be 
represented?   [Should  the  system  query  the 
user  or  vice  versa?   (EMYCIN  takes  the  first 
direction  toward  deriving  inferences.)] 
How  much  knowledge  is  required  to  cover  the 
subject?   (Specific,  scientific  subjects  lend 
themselves  far  more  readily  to  quantification 
than  do  more  subjective  domains.)   And  what 
is  the  required  information? 
Finally,  a  knowledge  base  must  be  modeled  and  the  tree 
of  subject-entities  (contexts)  arranged  so  that  the  questions 
asked  about  the  domain  are  contextually  sensible,  that  is, 
have  some  direction.   It  serves  little  purpose  for  the 
program  to  ask  questions  that  have  no  direction.   The 
knowledge  base's  context  tree  must  provide  this  understand- 
ing to  the  consultation-recommendation  session.   The  questions 
asked  during  the  consultation  must  be  asked  in  a  logical 
order  to  fill  in  the  knowledge  base.   This  can  be  partially 
accomplished  by  arranging  the  queries  in  an  order  that  makes 
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the  session  flow  in  a  smooth  manner.   When  the  entire  context 
tree  has  been  traversed,  inferences  are  produced  via  the 
system's  production  rules. 

The  EMYCIN  system  developed  at  Stanford  University 
provides  a  framework  for  building  consultation  programs  in 
any  quantifiable  field.   The  domain  independent  components 
of  production  rule  systems  and  backward-chaining  mechanisms 
manipulate  the  information  in  the  knowledge  base.   More 
specifically,  EMYCIN/DECAIDS  uses  an  evolving  knowledge 
base  composed  of  declared  parameters  and  rules  for 
concluding  goals. 

The  knowledge  base  contained  in  DECAIDS  is  designed 
to  support  a  prototype  managerial  decision  aiding  tool. 
While  the  recommendations  rendered  by  DECAIDS  are  straight- 
forward, it  must  be  remembered  that  the  primary  goal  of 
this  research  was  to  demonstrate  a  capability  of  designing 
and  implementing  a  decision  support  system  based  on  AI . 
While  previous  AI  research  programs  have  been  directed 
toward  more  structured  applications,  the  current  research 
investigates  an  area  which  is  relatively  unstructured  and 
very  subjective.   Previous  applications,  for  example, 
the  subject  of  blood  chemistry,  will  produce  many  specific 
statements  and  rules  relative  to  the  chemical  conditions 
affecting  a  person's  health. 

The  system  designer  must  know,  and  model,  exactly  what 
goal  his  system  is  to  achieve  before  he  attempts  to  write 
production  rules.   This  requirement  must  be  kept  in  mind 
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so  that  the  knowledge  base  will  be  property  supported  by 
the  elements  of  the  knowledge  base.   The  knowledge  base 
contains  two  types  of  elements.   These  elements  are  rules 
and  parameters  which  are  used  by  the  EMYCIN  inference  engine 
to  support  the  search  for  a  recommendation. 

Each  of  these  elements  is  described  by  a  list  of  its 
respective  properties.   The  definition  and  instructions 
concerning  these  properties  are  contained  in  Section  VII. 
The  rules  are  the  sentences,  (If  condition. .. then  action) 
statements,  which  imply  the  value (s)  of  parameters.   The 
parameters  are  the  nouns  used  in  the  sentences.   One  or  more 
of  these  parameters  will  be  identified  as  the  root  parameter(s) 
in  the  root  context.   The  remainder  of  the  parameters  are 
used  to  help  define,  find  a  value  for,  this  root  parameter (s) . 
The  rules  are  the  statements  which  ask  for  the  needed  values 
and  produce  the  recommendations.   These  questions  may  be  asked 
either  explicitly  from  the  system  user  or  implicitly  from  the 
system  itself. 

The  specific  syntax  for  the  rules  and  parameters  are 
explained  and  demonstrated  in  following  sections  of  this 
paper.  The  current  knowledge  base  consists  of  forty-one 
rules  and  twenty-three  parameters. 
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III.   PREDICATE  CALCULUS 

The  predicate  calculus  is  a  system  of  logic  in  which  it 
is  possible  to  express  complex  logical  statements  as  well  as 
mathematical  and  natural  language  statements.   The  system 
has  rules  of  inference  that  permit  valid  logical  deductions 
of  new  statements  to  be  made  from  a  set  of  given  ones.   The 
most  often  used  rule  of  inference  is  that  of  modus  ponens . 
The  inference  rules  produce  well-formed-formulas  from  given 
ones.   Predicate  calculus'  generality  and  logical  power  are 
important  vehicles  for  performing  deduction  [Nilsson,  1978]. 

AI  production  systems  are  based  on  the  formulas  of  the 
predicate  calculus.   A  production  is  a  rule  consisting  of  a 
situation-recognition  element  and  an  action  element.   Thus 
a  production  is  a  situation-action  pair  in  which  the  left, 
recognition,  element  is  a  list  of  conditions  to  ascertain  or 
test  and  the  right,  action,  element  consists  of  a  list  of 
things  to  do  or  conclude.   A  list  may  contain  only  a  single 
element.   When  productions  are  used  in  deductive  systems, 
the  situations  that  trigger  a  production,  or  rule,  are 
specified  combinations  of  facts.   The  actions  are  restricted 
to  being  assertions  of  new  facts  deduced  directly  from  the 
triggering  combinations.   The  productions  may  be  called 
premise-conclusion  pairs  rather  than  situation-action 
pairs.   The  action  of  triggering  premises  and  conclusions 
is  based  upon  the  use  of  predicates  and  predicate  logic. 
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Production  rules  are  spoken  of  as  "firing"  which  refers  to 
the  action  taken  by  predicate  functions  [Waterman,  1976]. 

A  programming  language,  using  the  predicate  calculus 
logic,  and  specified  by  some  syntax,  is  used  to  make  asser- 
tions about  some  domain  of  interest  --  to  provide  state 
descriptions  about  which  some  conclusions  will  be  made 
[Winston,  1977,  p.  257].   The  class  of  expressions  referred 
to  as  well  formed-formulas  (WFF)  is  the  basis  for  the  asser- 
tion clauses  of  a  particular  language.   The  WFF's  are  used 
as  the  contents  of  a  knowledge  base  and  are  permitted  values 
of  true  or  false.   Techniques  for  manipulating  WFF's  permit 
an  AI  program  to  reason  about  a  domain  and  ultimately  make 
or  reach  a  conclusion  [Nilsson,  1979],   The  method  of  opera- 
tion is  that  WFF's  are  applied,  modify  a  knowledge  base  and 
eventually  meet  some  termination  conditions. 

The  well-formed-formula  (WFF)  is  given  meaning  by 
interpreting  it  (the  WFF)  as  concluding  some  statement  about 
a  domain  of  discourse.   For  example,  the  domain  of  interest 
in  this  research  is  the  set  of  statements  concerning  a 
decision  support  system.   Conclusions  drawn  from  this  domain 
involve  relationships  among  statements  in  the  set  of  WFF's. 

The  WFF's  have  values  of  true  or  false  derived  from  the 
use  of  predicates  (words  or  functions  which  direct  some 
action  be  taken)  whose  values  in  turn  may  be  true  or  false. 
The  predicates  perform  the  action  of  mapping  elements  of 
the  domain  (elements  in  the  knowledge  base)  onto  other 
elements  of  the  domain  (actually  a  local  consultation  or 
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session  database).  The  WFF's  are  driven  by  the  predicates  of 
a  language,  the  elements  in  the  domain,  and  the  relationships 
between  the  elements. 

Each  WFF  can  be  assigned  a  value  of  true  or  false  and 
these  values  are  used  to  obtain  a  final  concluding  value. 
The  values  for  a  WFF  are  referred  to  as  certainty  factors. 
Certainty  factors  are  based  on  probabilistic  reasoning  and 
represent  a  rule  weight  assigned  by  a  system  designer  or  by 
an  expert  from  whom  knowledge  base  information  has  been 
obtained.   The  WFF  (premise)  which  evaluates  successfully 
provides  a  value  between  -1  and  1.   Those  rules  with  true 
premises  have  their  actions  evaluated  and  a  conclusion  is 
made  with  a  certainty  equal  to  the  premise  value  times  the 
certainty  factor  [Davis,  1977]. 

A.   LOGICALLY  FOLLOWS  AS  A  PROOF 

The  concept  which  allows  a  recommendation  or  conclusion 
to  be  produced  is  the  idea  of  a  WFF  being  a  logical 
consequence  of  a  given  set  of  WFF's.   This  is  formally 
stated  as  the  theorem  of  modus  ponens  which  is:   If  a  state- 
ment, A,  is  valid  and  A  implies  a  statement,  B,  then  B  is 
valid.   The  premises  of  the  production  rules  are  the  WFF's 
of  the  domain  of  discourse.   These  premises  or  WFF's  may 
further  be  divided  into  clauses  representing  multiple  con- 
ditions with  each  clause  being  evaluated  for  its  true  value 
[Nilsson,  1978]. 
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The  implication  of  the  preceding  is  that  a  "goal"  in 
the  EMYCIN  system  is  the  determination  of  the  value  of  some 
parameter.   This  parameter's  value  is  derived  as  a  result  of 
the  inferences  of  the  WFF's.   Each  rule  may  have  one  or  more 
clauses  in  its  premise  with  the  clauses  of  one  rule  joined 
by  an  "AND"  function.   All  conditions  in  a  single  premise 
must  be  true  in  order  to  fire  the  right-hand-side  of  a  rule. 
The  list  of  rules  is  a  set  of  conditions  joined  by  a 
logical  "OR"  function.   As  such,  any  or  all  of  the  rules  may 
succeed  and  give  the  subject  parameter  a  value.   Which  value 
to  present  to  the  consultation  system  user  is  a  combination 
of  certainty  factors,  probabilistic  reasoning,  and  expert 
judgmental  knowledge  [Scott,  1979]. 
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IV.   AND/OR  TREES 

The  concept  of  a  tree-structured  logic  diagram  is 
utilized  in  Artificial  Intelligence  applications  to  depict 
a  graph  of  nodes  representing  state  descriptions  which  are 
parameter  values.   A  tree  is  referred  to  as  a  context  (or  a 
context  tree  depending  upon  the  size  of  the  domain  of  dis- 
course) and  state  descriptions  are  the  parameters  of  the 
context.   Parameters  in  turn  may  have  sub-goals  used  to  find 
out  or  trace  their  values.   These  sub-goals  are  additional 
parameters  used  in  other  rules.   Values  are  determined  by 
traversing  the  tree  and  applying  rules. 

The  tree  traversal  method  used  in  DECAIDS  is  called 
"backward  chaining"  and  is  described  as  beginning  a  search 
at  some  goal  state  and  proceeding  to  some  initial  state.   To 
be  more  specific,  the  hierarchial  structure  of  tree  nodes,  or 
state  descriptions,  where  a  node  may  have  more  than  one 
parent,  is  properly  called  a  graph.   This  may  be  the  case 
with  multiple  rules  applying  to  a  specific  situation.   In 
the  case  of  multiple  rules,  a  control  strategy  must  be 
implemented  to  select  and  execute  rules  in  a  logical  manner. 
This  control  strategy  must  have  some  system  for  selecting 
relevant  rules  --  some  special  knowledge  of  the  problem  to 
be  solved  or  how  the  program  works.   The  control  strategy 
used  in  EMYCIN  and  DECAIDS  is  the  listing  of  sets  of  rules 
into  groups  pertinent  to  only  certain  states  or  declared 
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parameters.   This  grouping  serves  to  focus  the  tree  traversal 
towards  the  desired  initial  state  from  some  goal  state. 

The  backward- chaining  traversal  method  is  used  with  AND/ 
OR  trees.   The  name  "AND/OR"  is  derived  from  the  fact  that 
the  clauses  in  the  action  part  of  any  rule  are  considered  to 
be  operated  upon  by  an  "and-ing"  function.   Separate  rules 
in  a  knowledge  base  are  considered  to  be  operated  upon  by 
an  "or-ing"  function.   The  junctions  of  the  rules  clauses 
and  the  rules  make  up  the  nodes  of  the  AND/OR  tree. 

AND/OR  trees  facilitate  control  strategies  in  decomposable 
production  systems  such  as  DECAIDS.   An  explanation  of  a 
decomposable  system  follows:   A  rule  application  only  affects 
that  component  of  the  global  knowledge  (accessible  to  all 
rules)  used  to  state  the  rule's  premise.   The  decomposition 
of  the  knowledge  base  is  represented  by  an  atom,  one  parameter, 
at  a  time  being  affected  (modified,  added,  or  deleted) .   A 
primary  benefit  of  the  decomposable  system  is  that  redundant 
paths  are  not  searched. 

An  example  of  the  decomposition  of  a  production  system 
is  a  rewriting  rule  such  as  B  implies  Cj  which  produces  a 
string  of  all  Cj's  from  some  arbitrary  string  of  capital 
letters.   The  objective  is  to  establish  the  sequence  of 
rewriting  rules  which  produces  the  string  of  all  Cj's.   Each 
step  in  the  sequence  is  a  decomposed  part  of  the  system.   The 
premise  clause  of  a  system's  rules  form  the  AND  nodes  and 
junctions  of  multiple  rules  form  the  OR  nodes  in  a  tree. 


21 


Those  rules  whose  preconditions,  or  premise  clauses,  evaluate 
to  true  provide  the  path  to  a  desired  state  [Nilsson,  1978, 
p.  1-52].   This  structure  of  the  AND/OR  tree  is  used  in 
DECAIDS  to  select  relevant  rules  and  to  calculate  the  final 
strength  of  each  rule.   These  strengths  or  weights  are 
referred  to  as  certainty  factors. 

A.   CERTAINTY  FACTORS 

Certainty  factors  provide  a  methodology  for  quantitatively 
supporting  the  reasoning  of  production  rules.   A  numerical 
value  is  assigned  to  each  rule  conclusion  when  that  rule 
is  added  to  the  knowledge  base.   This  is  done  by  the  rule 
writer.   The  value  assigned  is  not  considered  to  be  a 
probability  but  more  of  some  "expert's"  judgmental  reasoning, 
and  values  are  permitted  to  range  from  minus  one  to  plus  one. 
The  certainty  factors  are  passed  along  an  AND/OR  tree  in  the 
following  manner  [Davis,  1977,  p.  22]. 

The  "and"  function  is  a  minimization  function  affecting 
production  rules  which  contain  one  or  multiple  preconditions 
or  clauses.   Minimization  is  effected  by  the  fact  that  the 
conclusion  of  a  single  production  rule  can  never  be  stronger 
than  the  weakest  piece  of  information. 

The  "or"  function  is  a  maximization  function.   Accord- 
ingly, the  certainty  factors  of  multiple  rules  reinforce 
(or  detract  from)  one  another.   From  any  "or"  function  the 
cumulative  certainty  factor  is  the  algebraic  sum  associated 
with  rules  leading  to  that  node.   The  final  conclusion's 
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certainty  factor  is  again  the  algebraic  sum  of  the  rule 
certainty  factors  leading  to  the  root  node.   If  a  certainty 
factor  falls  below  .2,  an  arbitrary  threshold  for  EMYCIN/ 
DECAIDS,  the  conclusion  is  not  utilized  and  the  situation 
is  considered  as  having  no  rule  to  conclude  about  it 
[Winston,  1977,  p.  245] . 
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V.   PRODUCTION  SYSTEMS 

As  with  conventional  computer  programs,  Artificial 
Intelligence  programs  are  characterized  by  data,  operations, 
and  a  control  strategy.   An  AI  program  is  more  specifically 
seen  to  have  a  global  database,  a  production  system  of  rules 
to  accomplish  operations,  and  a  control  strategy  to  determine 
which  rules  to  apply  and  in  what  order  [Nilsson,  1978]. 

A  production  rule  program  contains  a  set  of  rules. 
This  program  (DECAIDS)  is  the  set  of  rules  which  is  defined 
by  some  production  system  architecture  (EMYCIN)  referred  to 
as  a  production  system.   Each  of  these  rules  has  one  or  more 
preconditions  to  be  verified.   Upon  verification  of  these 
preconditions  (or  premise  clauses),  the  rule's  conclusion 
statement  will  be  executed.   Information  in  a  knowledge  base 
may  be  modified,  deleted,  or  added  by  the  action  of  a  rule 
[Waterman,  1976,  p.  3]  . 

In  affecting  parameter  values,  rules  are  considered  to 
be  modularized  pieces  of  coding  and  distinct  pieces  of  infor- 
mation.  Each  is  a  separate  "chunk"  of  knowledge  used  in  the 
program  [Davis,  1977,  p.  7].   In  performing  operations  on  a 
knowledge  base,  rules  are  controlled  by  a  rule  monitor  and  a 
rule  interpreter.   A  rule  monitor  is  a  subroutine  designed 
to  affect  the  desired  control  strategy  while  a  rule  inter- 
preter is  a  subroutine  called  by  the  monitor  to  execute 
rules  and,  thereby,  determine  the  values  of  parameters. 
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These  functions  will  be  explained  in  detail  later  in 
this  section. 

When  individual  rules  modify  the  knowledge  base,  no 
extensive  changes  to  program  code  are  necessary  because 
each  rule  is  modularized.   However,  it  must  be  noted  that 
while  the  rules  and  parameters  may  be  added  or  deleted 
without  requiring  any  changes  in  the  knowledge  base,  their 
additions  or  deletions  may  affect  the  logic  required  to 
present  a  complete  path  of  question-asking  reasoning  to  a 
root  node.   Due  care  must  be  exercised  not  to  disturb 
the  backward-chaining  path  used  to  reach  a  logical  conclusion, 

In  using  a  production  system  to  address  a  problem,  three 
areas  must  be  addressed:   problem  states,  the  rules,  and 
termination  conditions.   Problem  states  are  the  total  number 
of  alternative  solutions  possible  to  achieve  a  goal.   This 
may  also  be  referred  to  as  the  problem  space.   These  alter- 
natives must  be  formulated  into  some  standard  computer  pro- 
gramming data  structure  for  program  use.   Lists  have  been 
used  by  Artificial  Intelligence  programmers  as  the  most 
appropriate  data  structure.   Accordingly,  LISP  and  INTERLISP 
are  currently  the  most  often  used  languages  for  AI  applica- 
tions.  State  descriptions  serve  the  purpose  of  describing 
rule  preconditions.   The  approach  to  a  problem  in  an  AI 
program  is  through  a  sequence  of  state  descriptions  and  rule 
applications  which  modify  a  knowledge  base  to  arrive  at  some 
termination  condition.   The  rule  monitor  is  responsible  for 
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recognizing  the  termination  state  or  condition  as  specified 
by  the  system  designer. 

The  control  strategy  has  the  responsibilities  of 
selecting  rules,  accounting  for  problem  states  (parameter 
values),  and  accounting  for  rule  usage.   There  are  two  basic 
control  strategies:   irrevocable  and  tentative.   The 
irrevocable  method  applies  a  rule  with  no  reconsideration 
of  its  effect  on  a  knowledge  base.   An  example  of  a  tenta- 
tive system  is  the  backward-chaining  used  in  DECAIDS. 
Reconsideration  of  a  rule's  effect  is  seen  as  the  continual 
computation  of  certainty  factors  along  a  traversal  of  the 
AND/OR  tree.   Control  strategies  may  further  be  explained  by 
describing  two  types  of  production  systems,  condition- 
driven  and  action-driven  [Nilsson,  1978,  p.  1-22]. 

A.   TYPES  OF  PRODUCTION  SYSTEMS 

In  general  there  are  two  types  of  production  systems: 
condition-driven  and  action-driven.   The  method  of  inter- 
action with  the  knowledge  base  is  the  deciding  factor  between 
the  two.   In  a  condition-driven  system,  the  conditions  of 
the  premises  are  compared  to  the  database  and  the  rules 
whose  conditions  match  the  database  are  chosen  to  have  their 
Right-Hand-Side  (RHS)  executed.   The  action-driven  system 
interacts  with  the  knowledge  base  by  first  checking  the  RHS ' s 
This  procedure  parallels  a  logical  implication  with  its  "1 
and  2  imply  3"  statements.   The  system  attempts  to  prove  that 
3  is  true  by  checking  for  3  in  the  database  and,  if  this  is 
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false,  then  proving  that  1  and  2  are  true  --  therefore  3  is 
true  --  and  adding  3  to  the  database  [Waterman,  1976,  p.  3]. 

A  conflict  set,  in  a  condition-driven  system,  is  the 
collection  of  all  rules  whose  Left-Hand-Sides  (LHS)  have 
proven  true.   Selection  of  the  appropriate  rule  to  execute 
is  an  action  called  conflict  resolution.   The  most  often 
used  technique  is  rule  ordering  where  each  rule  is  previously 
assigned  some  priority  value  and  the  rule  with  the  highest 
value  is  executed. 

EMYCIN  and  DECAIDS  are  primarily  action-driven  systems. 
A  premise  is  presented  to  the  system  to  be  evaluated  either 
true  or  false.   The  premise  may  be  proved  true  by  the  user 
providing  an  answer  to  a  question  or  through  deductive 
inference.   The  method  for  proving  the  premise  is  to  examine 
the  actions  of  rules  to  find  one  which  would  make  the  premise 
true.   All  clauses  of  the  premise  must  prove  true.   The 
following  is  an  example  of  an  action-driven  problem  solution: 

DATABASE:   A  F 
RULES : 


1. 

A 

5 

B 

§ 

C 

=    D 

2. 

D 

$ 

F 

=    G 

3. 

A 

$ 

J 

=    G 

4. 

B 

=    C 

5. 

F 

=    B 

6. 

L 

=   J 

7. 

G 

=   H 
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The  goal  is  to  prove  H  true.   The  system  first  checks  the 
database  to  find  H.   If  this  fails,  which  it  does  here,  the 
system  tries  to  deduct  that  H  is  true  by  using  the  rules 
that  contain  H  on  the  RHS's.   The  first  relevant  rule  is  7. 
G  is  next  sought  in  the  database  since  if  G  is  in  the  data- 
base then  H  is  true.   Therefore,  rules  containing  G  must 
now  be  tried.   Rules  2  and  3  apply  and  these  may  be  assumed 
to  be  rule  ordered.   D  and  F  must  be  proven  and  this  is 
accomplished  via  proving  A  true  in  the  database,  B  and  C  are 
true  from  5  and  4,  and,  finally,  D  and  F  are  true,  G  is  true 
and  H  is  true.   As  the  rules  are  executed,  the  newly  proved 
elements  are  added  to  the  database  [Waterman,  1976,  p.  6]. 

This  simple  example  of  an  action-driven  system  should  be 
kept  in  mind  when  the  reader  begins  to  write  rules,  complete 
the  knowledge  base,  about  a  specific  domain  of  information. 
More  specifically,  the  source  of  a  value  for  a  parameter 
should  be  considered  --  from  the  user  or  from  a  knowledge 
base  search. 

B.   THE  EMYCIN  INFERENCE  ENGINE 

Researchers  in  Artificial  Intelligence  have  recently 
attempted  the  solution  of  some  real-world  problems.   Infec- 
tious blood  diseases,  pulmonary  functions,  aircraft  wing 
structural  analysis,  and  decision  aiding  systems  are  a  few 
of  the  subjects  considered  relevant  for  AI  applications.   In 
each  of  these  areas,  large  amounts  of  task-specific  knowledge 
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must  be  collected  to  build  a  knowledge  base.   This  information 
is  only  available  from  "experts"  making  assertions  about  a 
particular  subject  or  through  research.   However,  an  Arti- 
ficial Intelligence  program  must  provide  the  desired  utility 
before  it  will  draw  an  interest.   It  must  also  be  provided 
with  a  method  of  maintaining  an  evolving  body  of  information. 
The  use  of  production  rules  aid  these  two  AI  design  criteria 
[Davis,  1977]. 

This  thesis  includes  an  example  of  an  interactive 
decision  aiding  program  (DECAIDS) ,  designed  to  assist  the 
middle/top-level  manager  or  commander  in  making  decisions 
concerning  acquisition  and  use  of  automation  within  his 
organization,  and  when  given  certain  organizational  charac- 
teristics, to  determine  an  appropriate  organizational 
structure.   Additionally,  the  method  of  data  acquisition 
which  provides  for  a  system  creditability  and  maintains  an 
evolving  knowledge  base  will  be  explained.   The  "Essential" 
MYCIN  (EMYCIN)  inference,  production  rule,  engine  is  the 
programming  vehicle  used  to  accomplish  deductions  and  pro- 
duce conclusions  in  DECAIDS.   (The  name  MYCIN  was  given  to  the 
production  rule  program  which  was  first  concerned  with  infec- 
tious blood  diseases  because  many  medicines  ended  with  the 
suffix  "-mycin."   EMYCIN  is  an  extension  of  the  original 
system  to  other  domains.   The  term  "inference  engine"  refers 
to  the  concept  of  EMYCIN  being  a  soft  machine  which  produces 
inferences.)  [Scott,  1979].   The  inference  engine  modules  are 
depicted  in  Figure  V-l. 
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The  advice  sought  from  the  system  is  provided  by  the 
interactive  consultation  session.   Three  other  system 
utility  programs  exist  for  extending  the  knowledge  base 
(the  acquisition  program) ,  for  providing  reasons  for  a 
conclusion  (the  explanation  program) ,  and  for  answering 
natural  language  questions  about  the  knowledge  base  (the 
question-answering  program) .   The  question-answering  program 
requires  an  extensive  library  of  domain  definitions  and  is 
currently  not  in  use  in  EMYCIN.   These  modules  occupy  a 
total  of  130K  of  nonshared  code,  are  written  in  INTERLISP, 
and  run  fast  enough  for  real-time  interaction  [Davis,  1977], 

The  DECAIDS  domain  specific  knowledge  consists  of  less 
than  50  production  rules.   Each  rule  contains,  as  mentioned, 
a  premise  and  an  action.   The  premise  is  a  Boolean  combination 
of  predicate  functions  on  associztive  triples  with  each 
premise  clause  containing  a  predicate  function,  an  object 
(context),  and  an  attribute  (parameter)  value.   An  example  of 
a  clause  in  English  is: 


■o  ' 


"If:   The  structure  of  organization  is  line," 

and  in  INTERLISP  syntax  is , 

"($AND  (SAME  CNTXT  STRUCTURE  LINE))" 

The  "then"  part  of  the  rule  is  the  conclusion  statement. 
Appendix  E  contains  a  listing  of  the  standard  predicate 
functions  used  in  premise  and  conclusion  statements.   The 
premises  are  evaluated  in  INTERLISP  to  test  for  their 
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validity  and  the  conclusion  action  performed  if  "true"  is 
the  premise  value.   Known  conditions  are  saved  in  the 
"session  database"  by  a  rule  adding  that  condition  [Davis, 
1977]  . 

1.   Rule  Invocation  Procedures 

Rules  are  called  in  a  backward- chaining  manner  which 
produces  a  depth-first  search  of  an  AND/OR  tree,  e.g.,  this 
search  proceeds  down  the  branches  of  a  tree  first  rather 
than  across.   When  given  a  goal  to  achieve,  the  system 
retrieves  the  list  of  rules  whose  conclusions  bear  on  the 
goal  --  the  right-hand-sides  are  scanned  and  the  goal  sought 
for  in  the  knowledge  base  by  the  monitor  subroutine.   The 
INTERLISP  function  "EVAL"  is  the  rule  interpreter  for 
evaluating  the  premise  of  a  rule.   (In  INTERLISP,  an  "s- 
expression"  is  an  atom  or  may  be  a  list;  "s"  is  an  abbreviation 
for  "symbolic."   An  EVAL  function  in  INTERLISP  returns  the 
value,  TRUE  or  NIL,  of  an  evaluated  s-expression. )  [Winston, 
1977,  p.  266].   No  additional  work  is  required.   Rules  whose 
premises  are  evaluated  false  are  bypassed  and  those  for  which 
an  answer  cannot  be  determined  have  sub-goals  created  for 
them  and  a  rule  search  recurs . 

These  sub -goals  take  the  form  of  "find  the  value  of  the 
parameter"  of  the  premise.   "By  setting  up  the  generalized 
goal  of  collecting  all  evidence  about  a  parameter,  the  program 
exhausts  each  subject  as  it  is  encountered  and  tends  to  group 
together  all  questions  about  a  topic.   This  presents  a  more 
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orderly  approach  to  the  problem."  [Davis,  1977,  p.  9]. 
If  after  trying  all  relevant  rules  about  a  sub-goal,  the 
certainty  factor  associated  is  still  between  -.2  and  .2, 
then  the  sub-goal  is  still  considered  as  unknown.   "This 
may  happen  if  no  rule  were  applicable,  the  applicable  rules 
were  too  weak,  the  effects  of  several  rules  were  offsetting, 
or  if  there  were  no  rules  for  the  sub-goal  at  all."  [Davis, 

'  p'    ■'■"   EMYCIN  provides  the  pattern  matching  capa- 
bilities and  INTERLISP  provides  the  evaluating  functions  -- 
the  user  or  system  writer,  who  completes  the  knowledge  base, 
must  furnish  all  concluding  rules.   If  no  value  can  be 
deduced,  then  the  user  may  be  asked  for  a  value.   A  value 
may  be  an  alphabetic  value.   A  "?"  will  present  a  list  of 
acceptable  values  to  the  user  during  a  consultation. 

In  some  cases,  the  user  is  assumed  to  always  have 
the  answer  to  certain  questions  for  which  there  should  be 
no  need  to  spend  time  searching.   Name,  rank  and  social 
security  number  are  examples  of  such  information.   In  this 
case,  where  the  user  is  immediately  expected  to  provide  a 
parameter  value,  the  answer  to  a  question,  that  parameter  is 
declared  with  a  property  called  LABDATA.   This  LABDATA 
property  will  have  a  value  of  true  declared  and  the  user 
will  be  prompted  with  a  plain  language  text  question  request 
ing  the  subject  parameter's  value.   This  plain  language  text 
question  is  maintained  in  a  parameter  property  called  PROMPT 
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and  the  acceptable  or  permitted  values  for  a  parameter  are 
kept  in  a  property  called  EXPECT. 

In  the  interest  of  efficiency,  rules  are  "previewed" 
for  clauses  whose  values  are  already  known  and  would  thus 
make  the  entire  premise  false.   There  would  then  be  no  need 
to  evaluate  this  rule.   When  running  a  consultation  with  the 
highest  level  fault  trace  turned  on  (FT4) ,  a  rule  found 
false  during  this  preview  will  receive  the  following  message: 
"Rule  #,  Failed  in  Preview  Due  to  Clause  #."   The  Boolean 
logic  for  this  situation  is  False  and  True  =  False. 

The  "previewing"  facility  is  accomplished  with  a  data 
structure  called  a  template  used  with  each  predicate  func- 
tion.  Each  template  has  the  basic  form  of  (function-context- 
parameter  value)  and  uses  internal  flags  to  determine  if  a 
parameter  has  been  previously  used  with  this  function  and 
whether  it  is  true  or  false  in  this  clause. 

The  last  action  seen  during  rule  invocation  is  the 
use  of  antecedent  style  or  definitional  rules.   If  a  conclu- 
sion is  made  which  matches  the  premise,  these  antecedent 
rules  are  invoked  with  a  certainty  factor  of  1.0.   After 
desired  parameter  values  have  been  determined,  an  antecedent 
rule  is  used  to  produce  the  system's  output,  i.e.,  once  the 
parameters  describing  the  context  ORGANIZATION  are  known,  then 
an  inference  can  be  made  with  a  definitional  rule  recommending 
the  organization  should  use  a  particular  type  of  computer 
installation  [Davis,  1977]. 
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C.   DATA  ACQUISITION 

Since  any  domain  of  information  can  be  expected  to 
change,  a  capability  to  add  and  delete  pieces  of  knowledge 
must  be  provided.   The  updating  of  an  evolving  knowledge 
base  is  necessary  to  give  the  subject  system  acceptability 
and  recognized  competence  [Williams,  1978,  p.  3].   The 
addition  of  knowledge  to  a  system  is  accomplished  by  the 
system  writer  or  user  producing  the  production  rules  using 
the  INTERLISP  syntax  described  later.   EMYCIN  and  DECAIDS 
scan  new  rules  provided  by  the  expert  to  find  key  words 
which  indicate  the  appropriate  predicate  functions  and  a 
template,  function-context-parameter-value  tuple,  to  be 
retrieved.   Values  provided  for  the  parameters  must  be  a 
member  of  the  parameter's  EXPECT  property,  the  list  of  per- 
mitted or  expected  values  for  that  parameter.   Upon  comple- 
tion of  the  parse  of  the  rule,  the  new  rule  is  added  to  the 
appropriate  list  of  relevant  rules  of  the  same  rule  group 
[Davis,  1977,  p.  25] . 

When  adding  new  rules,  direct  contradictions  should  be 
avoided.   While  the  certainty  factor  computations  will 
provide  a  resolution,  the  strength  of  the  consultation 
recommendation  will  be  weakened  by  contradicting  rules. 
New  values  and  parameters  must  also  be  updated  throughout 
the  information  structure  of  the  system.   While  new  rules 
may  be  added  without  regard  for  deleting  old  ones  (only  the 
true,  relevant  rules  will  be  executed),  parameter  values 
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must  be  kept  abreast  of  current  technology.   Finally,  the 
additions  of  not  just  a  single  rule  but  the  addition  of  an 
entire  concept  must  be  carefully  planned  when  being  added 
to  a  knowledge  base.   A  single  rule  is  easily  expressed  and 
added  to  the  program.   However,  a  set  of  rules,  stated  in 
the  backward -chaining ,  goal-directed,  manner  is  not  a  normal 
human  method  of  expression.   Due  care  must  be  exercised  in 
writing  a  logical  ordering  of  rules  to  achieve  a  complex 
concept  or  goal.   Written  first  in  the  system  writer's 
natural  language  (i.e.,  English)  the  question  asked  of  the 
user  (or  implicitly  of  the  system)  will  be  the  rule  concluding 
the  parameter  values. 

This  is  an  example  of  the  modeling  process  used  to  write 
production  rules  and  fill  a  knowledge  base. 

1.  A  system  designer  has  been  tasked  to  accept  ideas 
from  an  organizational  theorist  and  information  analyst  and 
to  produce  production  rules  leading  to  a  recommendation 
concerning  computer  resource  utilization. 

2.  It  has  been  decided  that  STRUCTURE,  the  name  of  an 
organization,  may  have  one  of  two  possible  organizational 
types:   LINE  or  MATRIX.   STRUCTURE,  LINE  and  lMATRIX  will  be 
used  by  the  system  designer  as  parameters  in  the  knowledge 
base.   LINE  and  MATRIX  are  values  for  the  parameter  STRUCTURE. 

3.  It  has  further  been  decided  that  if  STRUCTURE  has 

the  value  of  LINE,  then  the  organization  is  recommended  to  use 
a  large  computer,  graphic  display,  and  batch  processing 
capabilities . 
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4.  Accordingly,  the  system  designer  decides  to  declare 
SIZE  (of  the  computer),  TYPE  (of  display),  and  MODE  (of 
processing)  as  parameters  with  values  of  large  or  small, 
printer  or  graphic,  and  interactive  or  batch,  respectively. 

5.  The  system  designer  next  verbalizes  a  premise: 
If  the  structure  is  line 

(and,  next  he  verbalizes  an  action) 

Then  strongly  suggest  a  large  computer  be  used 

(cf  .8) 

strongly  suggest  graphic  terminals  be  used 

(cf  .8) 

strongly  suggest  batch  processing  be  used 

(cf  .8) 

6.  Finally,  the  rule  is  written  in  INTERLISP  syntax: 
($AND  (SAME  CNTXT  STRUCTURE  LINE)) 

(DO-ALL  (CONCLUDES  CNTXT  SIZE  LARGE  TALLY  800)) 
(CONCLUDE  CNTXT  TYPE  GRAPHIC  TALLY  800)) 
(CONCLUDE  CNTXT  MODE  BATCH  TALLY  800)) 

7.  The  phrase  "TALLY  800"  is  the  required  certainty 
factor  syntax. 

D.   BASIC  SEARCH  METHOD  OF  EMYCIN/DECAIDS 

Searching  in  EMYCIN/DECAIDS  is  entirely  a  goal-directed, 
backward-chaining  process.   Each  "goal"  is  to  determine  the 
value  of  some  parameter.   The  chaining  starts  with  the 
parameter  which  the  system  builder  specifies  as  the  goal 
of  the  consultation.   This  is  the  value  or  values  in  the 
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GOALS  property  of  the  root  context  type.   This  GOALS 
property  is  actually  a  list  of  parameters  and  each  one  is 
traced  in  turn. 

To  trace  or  determine  the  value  of  a  context  parameter, 
the  control  structure  accomplishes  the  following: 

--If  the  parameter's  LABDATA  property  is  "T,"  then  the 
value  is  requested  of  the  consultation  system  user.   If 
the  user  responds  UNKNOWN  or  enters  a  certainty  factor  (cf) 
less  than  1.0,  and  if  there  exist  rules  that  conclude  the 
parameter,  then  these  rules  are  tried.   Once  all  rules  have 
been  tried,  the  system  knows  as  much  as  it  ever  will  about 
that  parameter.   If  the  parameter  does  not  have  a  "T"  value 
for  the  LABDATA  property,  the  rules  are  tried  first.   After 
all  have  been  tried,  and  still  nothing  is  "known"  about  the 
value  or  the  parameter  has  a  PROMPT,  the  user  will  be  asked 
the  question  (text)  in  the  PROMPT  property  for  which . certain 
answers  (values  in  the  EXPECT  property)  are  allowed.   Here 
"known"  means  a  cf  greater  than  .2  for  non-yes/no  answers 
and  a  cf  greater  than  .2  or  less  than  -.2  for  yes/no  parameters 
When  all  of  this  has  been  accomplished,  the  system  knows  as 
much  as  it  ever  will  about  that  parameter. 

The  previously  described  apparatus  is  called  the  FINDOUT 
mechanism  and  is  written  in  INTERLISP.   The  process  of  trying 
a  set  of  rules  is  called  the  EMYCIN  MONITOR  mechanism  and 
works  as  follows : 

The  system  starts  with  the  first  rule  in  the  list.   The 
UP-DATED-BY  property  of  a  parameter  is  the  list  of  rules 
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that  can  be  used  to  conclude  about  the  parameter.   This 
UP-DATED-BY  property  is  compiled  by  the  GETRULES,  rulewriting, 
program.   The  UP-DATED-BY  property  is  the  list  that  is  used 
by  the  MONITOR  mechanism  when  the  MONITOR  is  used  to  find 
out  a  parameter  value. 

Each  clause  in  a  rule's  premise  is  evaluated.   If  a 
clause  mentions  a  parameter  which  has  not  yet  been  traced, 
then  the  FINDOUT  mechanism  is  used  to  trace  it.   This  is 
where  the  backward-chaining  is  demonstrated.   The  system 
now  suspends  what  it  is  doing  and  sets  up  a  sub-goal,  i.e., 
to  find  out  the  parameter  that  is  needed  in  the  rule  currently 
being  processed.   The  backward-chaining  drives  the  consulta- 
tion:  It  is  what  causes  all  questions  to  be  asked  with  the 
exception  of  the  PROMPT'S  of  the  parameters  in  the  MAINPROPS 
property  of  the  contexts. 

--  If  the  clause  that  is  being . evaluated  fails,  then 
the  rule  is  discarded  and  the  system  MONITOR  mechanism  pursues 
the  next  rule  in  the  list.   If  the  rule  succeeds,  then  the 
next  clause  of  the  premise  is  evaluated.   When  there  are  no 
more  clauses  to  be  evaluated,  execution  of  the  ACTION  clause 
occurs . 

--  If  the  value  of  the  parameter  is  known  with  certainty 
(cf  =  1)  then  the  system  seeks  no  further,  and  goes  on  to  the 
next  rule  having  executed  the  action.   The  entire  process 
continues  until  each  rule  in  the  list  has  been  tried. 

The  only  exception  to  backward- chaining  is  in  ANTECEDENT 
rules.   These  are  rules  that  are  tried  as  soon  as  all  the 
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parameters  in  the  PREMISE  are  traced  as  opposed  to  the  rest 
of  the  rules  which  are  tried  in  order  to  find  out  the  value 
of  the  parameter  in  their  ACTIONS.   On  the  property  list  of 
a  parameter  the  ANTECEDENT-IN  property  is  a  list  of  ante- 
cedent rules  to  be  tried  when  the  parameter  has  been  traced. 
Once  the  parameters  have  been  traced,  the  rule  is  executed  - 
often  in  an  output  type  statement  [Scott,  1979]. 

E.   PARAMETER  TRACING  IN  A  CONTEXT  TREE 

EMYCIN/DECAIDS  performs  the  following  actions  in  order 
to  trace  the  value  of  a  parameter,  called  "PARM"  in  this 
example,  in  a  context,  called  "CNTXT."   The  rules  in  the 
parameter's  UP-DATED-BY  property  are  tried  one  by  one.   The 
rules  are  listed  in  the  UP-DATED-BY  property  by  the  GETRULES 
subprogram.   When  trying  a  rule,  called  "RULE,"  its  SUBJECT 
called  "GROUP,"  in  this  example,  is  compared  to  the  context 
type  of  "CNTXT,"  called  "TYPE."   "GROUP"  is  the  value  of 
RULE'S  subject  property  and  is  a  member  of  the  list  called 
ALLNAMES  --  the  name  of  the  list  for  rule  groups.   "TYPE" 
is  the  value  of  "CNTXT 's"  PROPTYPE  property.   This  value  is 
"PROP-VAL"  for  all  contexts. 

The  CONTEXT  property  of  a  rule  group  is  the  list  of 
context  types  to  which  RULE  can  apply.   By  convention,  a 
rule  may  reference  parameters  of  the  context  to  which  it 
applies  and  parameters  of  descendent  contexts.   It  may 
not  reference  parameters  of  contexts  lower  in  the  tree  -- 
nearer  the  root.   Therefore,  if  a  rule  is  relevant  to  CNTXT, 
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one  of  two  conditions  may  apply.   The  RULE  may  apply 
directly  to  CNTXT,  and  in  this  case,  the  CONTEXT  property 
of  GROUP  must  contain  TYPE  and  the  RULETYPES  property  of 
TYPE  must  contain  GROUP.   The  other  possibility  is  that  RULE 
applies  to  a  descendent  of  CNTXT.   TYPE'S  OFFSPRING  property 
is  the  list  of  context  types  that  may  be  below  CNTXT  in  the 
tree.   The  system  examines  each  of  the  OFFSPRINGS  of  TYPE 
(and  succeeding  OFFSPRING)  to  try  to  find  a  descendent  con- 
text type  to  which  RULE  can  apply.   If  any  such  lower  context 
is  found,  then  the  RULE  is  relevant.   Relevant  descendents 
of  CNTXT  are  collected  and  RULE  is  applied  to  each  of  these 
contexts  [Scott,  1979]. 

F.   INTERPRETING  THE  PRODUCTION  RULE  PROGRAM 

The  interpretation  of  a  production  rule  system  is  com- 
paratively simple.   The  procedure  involves  a  search  through 
the  knowledge  base  for  a  production  that  matches  the  pro- 
duction in  the  consultation  data-base.   DECAIDS  moves  back 
and  forth  searching  for  the  relevant  production  and  execu- 
ting the  rules  which  are  true.   The  action  of  searching  for 
a  rule  is  made  a  little  easier  through  the  ease  of  pattern 
matching  in  LISP  and  INTERLISP.   LISP  has  no  organic  pattern 
matching  capabilities  but  can  be  easily  programmed  for  this 
task.   The  basic  LISP  function  which  facilitates  this  in- 
terpreting is  called  COND.   COND  is  the  LISP  branching 
function  or  conditional  function.   The  COND  function  is 
followed  by  a  list  of  premise  clauses  to  be  tested.   The 


41 


pattern  matching  occurs  at  this  time  with  the  system, 
checking  in  accordance  with  the  GETRULES  "used-by"  property, 
looking  for  key,  or  matching,  expressions.   iMore  specifically, 
a  function  is  DEFINE' d  in  LISP  which  examines  the  elements 
of  the  rules  in  the  knowledge  base  and  the  consultation  data- 
base.  ("DEFINE"  is  a  LISP  function  which  permits  a 
function  declaration.   If  a  match  is  made,  a  recursive  call 
is  made  on  the  remainder  of  the  rules  to  be  matched.   If 
NIL  is  returned,  then  the  next  clause  is  examined  [Winston, 
1977]  . 

G.   PROS  AND  CONS  OF  PRODUCTION  SYSTEMS 

There  are  several  advantages  and  some  disadvantages  in 
using  the  production  rule  architecture.   Production  rules 
represent  a  form  of  code  modularization.   Each  production 
rule  is  a  self-contained,  modular  piece  of  code  independent 
of  other  rules  in  execution.   The  advantages  of  modular 
coding  are  well  known.   Such  a  technique  greatly  aids  the 
task  of  managing  very  large  and/or  evolving  database. 
Parsing  new  rules  to  be  added  to  the  appropriate  internal 
lists,  relevant  to  a  goal,  is  made  easier.   The  production 
rules  are  a  succinct  form  of  knowledge  representation.   Each 
is  easily  written  and  retrieved.   Unlike  other  high-level 
languages,  no  changes  in  previous  coding  need  be  made  in 
order  to  add  new  rules.   No  other  rule  must  be  altered  to 
ensure  that  the  new  one  will  be  called  and  executed 
[Winston,  1977].   The  use  of  the  RULE  GROUP  and  PROPGROUP 
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properties  and  the  key  word  search  of  the  function-parameter 
templates  ensures  that  only  relevant  rules  are  executed 
[Scott,  1979] . 

A  disadvantage  in  the  use  of  production  rules  is  the 
difficulty  in  expressing  series  of  rules  to  convey  a  complex 
concept.   The  modularized,  "if-then"  coding  does  require 
some  practice  in  the  area  of  "backward -thinking. "   The  rule 
writer  must  be  cautious  of  the  goal-directed  invocation  of 
rules  in  preparing  the  rules  [Winston,  1977,  p.  151]. 
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VI.   DECAIDS  KNOWLEDGE  BASE 

A.   BACKGROUND 

The  birth  of  decision  making  as  a  discipline  can  be 
traced  to  early  operational  analysis  techniques  employed 
during  World  War  II  [Williams,  1978,  p.  4].   iMore  recently 
there  has  been  considerable  debate  between  behavioral 
scientists  and  technically-minded  analysts  concerning  just 
what  decision  making  is.   Behavioral  scientists  believe 
that  decision  making  remains  the  province  of  organizational 
behavior  and  theory.   This  point  of  view  differs  drastically 
from  that  of  the  more  technically-minded  analysts  who 
believe  that  this  discipline  is  better  founded  in  quantita- 
tive methods  such  as  operations  research  and  management 
science.   The  differences  between  these  viewpoints  clearly 
point  to  the  fact  that  "decision  making  theory"  remains 
relatively  unformulated  [Williams,  1978,  p.  4]. 

The  capabilities  of  automatic  data  processing  techniques 
in  operational  and  management  tasks  (accounting  routines, 
record  keeping,  operations  control,  etc.)  are  well  known. 
The  use  of  these  techniques  by  mid-  and  high-level  managers 
beyond  these  "bookkeeping"  areas  is  not  yet  significant. 
There  are  two  major  reasons  for  this  lack  of  use  by  manage- 
ment to  assist  in  decision  making.   One  is  the  inability  to 
adequately  transfer  new  technologies  from  the  research/ 
academic  areas  to  the  manager.   However,  the  primary  reason 
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for  the  manager's  point  of  view  may  be  the  lack  of  a  model 
which  describes  the  organization  status  or  situation. 

B.   MODEL  DEVELOPMENT 

The  prototype  program  (DECAIDS) ,  as  described  in  this 
paper,  represents  an  attempt  to  identify  the  key  parameters 
affecting  organizational  managers  and  the  decisions  which 
they  must  make.   More  specifically,  this  decision  support 
program,  DECAIDS,  attempts  to  "quantify"  these  parameters 
in  order  to  deduce  recommendations  concerning  appropriate 
computer  system  capabilities.   These  recommendations  are 
based  upon  organizational  characteristics  described  by  the 
user. 

The  DECAIDS  knowledge  base  was  developed  from  the  final 
technical  report  prepared  for  the  Office  of  Naval  Research 
by  Spector,  Hayes,  and  Crain.   This  report  evaluates  the 
effects  of  computer-based  decision  aids  on  organization 
structure.   It  was  chosen  as  the  basis  for  DECAIDS  because 
it  specifically  addresses  the  subjects  of  decision  aids  and 
organizational  structure.   The  knowledge  base  is  not  con- 
sidered comprehensive;  rather  it  is  a  skeleton  which  can 
be  further  expanded  by  subsequent  research. 

The  current  knowledge  base  (Figure  VI-1)  has  ORGANIZA- 
TION as  the  root  context.   This  context  is  defined  by  the 
organization's  structure  and  environment.   The  following 
sections  of  this  chapter  describe  the  current  system 
parameters  and  the  ultimate  recommendations  which  are 
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reached  during  the  interactive  consultative  session(s) . 
During  the  following  discussions,  DECAIDS  program  parameters 
are  indicated  in  capital  letters. 

1.   Formal  and  Informal  Organization  Structure 

"Organization  structure  is  concerned  with  the  role 
and  personal  arrangements  within  an  organization  that 
specify  authority,  coordination,  and  communication  rela- 
tionships.  These  arrangements  link  functions  and  physical 
factors  to  manpower  requirements  and  availability."  [Spector, 
1978,  p.  31].   Simply  stated,  this  organizational  structure 
relates  to  the  internal  system  of  functioning  groups  -- 
the  processes  by  which  the  organization  operations  are  or 
should  be  accomplished.   The  organizational  structure  can 
be  further  subdivided  into  the  formal  and  informal  structures 

The  formal  structure  (FORMAL)  involves  the  official 
patterns  of  authority  and  the  location  of  responsibility 
and  accountability  within  the  organization.   Public  and 
private  sector  usage  has  resulted  in  the  identification  of 
four  basic  formal  structures.   These  four  categories  define 
the  different  lines  of  command  and  control,  advisory,  and 
functional  relationships.   The  four  basic  formal  structures 
used  in  DECAIDS  are:   line,  line  and  staff  (called  staff), 
functional,  and  project  manager  (called  matrix)  [Spector, 
1978,  p.  3-2] . 

Line  structure  emphasizes  direct  chains  of  authority 
and  unity  of  command  while  the  line  and  staff  includes  an 
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informational  and/ or  advisory  staff  to  assist/guide  line 
or  operational  personnel.   A  functional  structure  organizes 
personnel  by  functional  activity  or  type  of  task,  such  as 
supply,  planning,  or  communications  functions  [Spector, 
1978,  p.  5-2].   Finally  the  project  manager  (matrix)  structure 
organizes  specialists  from  specialized  organizational  units 
to  work  together  with  other  specialists.   "For  example, 
chemical,  mechanical,  industrial,  and  electronic  engineers 
may  work  together  in  a  team  with  physicists,  accountants, 
human  engineers,  and  other  professionals  to  develop  a  new 
product."   [Tosi,  1976,  p.  471].   In  this  structure,  the 
individuals  work  to  achieve  the  interdepartmental  goals. 

The  informal  structure  (INFORMAL)  describes  the 
system  of  transactions,  dynamic  and  interpersonal,  which 
occur  within  an  organization.   These  informal  processes, 
patterns,  and  relationships  develop  quite  naturally  as 
organizational  personnel  interact  to  handle  the  problems 
and  requirements  of  their  roles  in  their  own  particular 
styles.   While  the  organization's  formal  structure  estab- 
lishes the  division  of  labor  within  the  organization,  the 
informal  structure  identifies  the  reality  of  organizational 
behavior  and  performance  based  upon  the  individuals  involved. 

Spector  et  al.  (1978)  identified  five  informal 
structures.   These  five  informal  structures  which  have  been 
used  in  DECAIDS  are:   centralized,  consultative,  transac- 
tional, partially-delegated,  and  decentralized.   A  centralized 


48 


structure  employs  a  focused  flow  of  authority  to  a  single 
source  at  the  top  of  the  hierarchy.   Consultative- type 
informal  structures  maximize  patterns  of  central  control, 
but  encourage  vertical,  upward  communication  of  advice/ 
guidance  from  the  professional  staff.   Open  communication, 
deliberation,  and  negotiation,  not  only  vertically  among 
hierarchial  levels  but  laterally  among  levels  is  highly 
encouraged  by  transactional  structures.   This  type  structure 
does  not  preclude  the  ultimate  decision  remaining  with  the 
high  levels  of  the  hierarchy.   Another  form  of  informal 
structure  promoting  management  by  negotiation  is  the 
partially-delegated  structure.   This  system  distributes 
authority  among  the  professional  staff  while  increasing  the 
need  for  coordination  of  effort.   Under  this  arrangement, 
staff  personnel  have  authority  to  develop  action  alterna- 
tives with  top  management  retaining  the  right  to  approve, 
reject,  or  modify  these  options.   Finally,  the  decentralized 
structure  uses  a  high  degree  of  delegation  and  dispersal 
of  decision  making  authority  to  lower  levels  of  the  higher 
hierarchy. 

Formal  and  informal  structures  represent  the 
theoretical  and  realistic  arrangement  of  organizations, 
respectively.   Formal  structure  defines  a  set  of  decision 
methods  and  procedures  designed  by  management  in  order  to 
optimize  the  performance  of  the  organization.   The  formal 
structure  that  is  chosen  reflects  the  past  management 
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experience  and  is  based  upon  the  expected  personnel 
configurations.   The  informal  structure  defines  the  actual 
decision  methods  and  dynamic  problem-solving  processes  that 
are  used  to  motivate  organizational  performance. 

In  reality,  these  informal  structures  may  exist  in 
a  myriad  of  combinations  and  variations.   DECAIDS  uses  them 
individually  and  independent  of  one  another.   This  program 
also  offers  the  user  the  additional  choices  of  declaring 
both  formal  and/or  informal  as  not  known  (notavailable) . 
If  this  option  is  used,  the  program  contains  production  rules 
which  will  return  suggested  configurations  for  formal  and 
informal  structures. 
2.   Environment 

The  other  parameter  affecting  organizations  is  the 
environment  in  which  the  organization  must  operate.   There 
are  three  basic  factors  which  make  up  this  environment. 
They  may  be  described  as:   the  mission  to  be  accomplished, 
the  personnel  required  to  perform  the  mission,  and  the 
technology  available  to  perform  the  mission. 

The  model  defines  the  mission  in  terms  of  problem 
definition  (PROBDEF)  and  stress  level  (STRESS).   The  user 
is  asked  to  define  the  task  in  terms  of  problem  definition, 
either  clearly  defined  or  ambiguous.   Mission  stress  is 
defined  as  high,  low,  or  unknown. 

Personnel  environment  is  divided  into  two  categories 
concerning  the  leader  and  staff.   The  system  currently 


50 


contains  only  two  parameters  related  to  the  leader.   These 
are  the  leader's  style  (STYLE)  and  his  level  of  training 
(LEADER-TRAINING).   Leader  style  is  defined  as  either 
relation-oriented  or  task-oriented.   Relation-oriented  refers 
to  the  leader  who  gives  "little  direction  to  his  staff, 
encourages  them  to  actively  participate  in  setting  decision- 
making parameters,  and  values  the  development  of  personnel 
responsibility,  decentralized  informal  organization  structures 
provide  maximum  performance."  [Spector,  1978,  p.  4-20]. 
Conversely,  task-oriented  leaders  are  defined  as  those  who 
prefer  far  more  centralization  or  consultative  structure 
and  are  less  concerned  with  the  development  of  individual 
responsibility  in  the  decision-making  policy.   Leader- 
training  relates  the  level  of  training  in  the  use  of  the 
computerized  technical  aids  which  the  mission  leader 
currently  possesses  and  is  defined  as  either  skilled, 
unskilled,  or  unknown. 

The  staff  environment  is  currently  defined  by  only 
one  parameter,  staff -training  (STFFTRG) .   This  parameter 
relates  to  the  staff's  level  of  training  in  computerized 
technical  aids  and  is  either  skilled,  unskilled,  or  unknown. 

The  available  technology  relates  to  three  parameters: 
computer  system  status  (SYSSTAT) ,  the  technical  knowledge 
level  required  to  perform  the  mission,  and  the  purpose  of 
the  system's  use  (METHODS).   The  first  parameter,  computer 
system  status,  refers  to  the  implementation  or  operational 
status  of  the  organization's  computer  assets.   The  only 
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alternatives  currently  offered  are:   yes,  an  operational 
system  is  in  existence,  or  no,  there  is  none  in  operation. 
The  alternatives  allowed  for  knowledge  level  are  skilled  or 
unskilled.   The  other  parameter  used  to  define  technological 
environment  deals  with  the  use  of  the  system.   The  current 
accepted  responses  are  inventory  aids  or  analytical  aids. 
Inventory  aids  refer  to  the  more  administrative  type  uses. 
Analytical  aids  are  those  which  concern  more  scientific 
applications . 

3.   DECAIDS  Program  Goals 

The  program  which  has  been  developed  is  currently 
designed  to  support  three  goal  parameters.   These  goals  are 
decision  aid  characteristics  (DECAIDS),  formal  structure 
(FORSTRUC) ,  and  informal  structure  (UNSTRUC) .   Successful 
inference  of  the  first  parameter,  DECAIDS,  is  the  primary 
goal  of  the  current  program.   The  interactive  session 
between  the  program  and  user  is  aimed  at  deducing  the  most 
appropriate  decision  aid  characteristics  based  upon  the 
invoked  program  production  rules  which  in  fact  reflect  the 
user's  decision  making  environment. 

DECAIDS  is  composed  of  four  parameters  that  define 
various  characteristics  of  computer  decision  aids  (Figure 
VI-2).   The  current  definition  includes  the  recommended  type 
of  computer  system  (TYPSYS) ,  output  devices  (OUTPUT), 
computer  installation  arrangement  (INSTALL),  and  the  best 
training/assistance  alternatives  for  successful  implementation 
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(TRG) .   The  current  type  systems  recommended  are  real-time 
and  non  real-time.   The  output  devices  are  either  individual 
terminals  or  large  screen  displays.   The  possible  installa- 
tions are  divisional  and  pyramidal.   Divisional  installation 
places  authority  in  each  division  for  independent  systems 
while  pyramidal  installation  places  authority  at  the  top  of 
one  super-system  above  all  divisions.   The  final  parameter 
reflects  the  training  needed  or  assistance  required  by  the 
organization  in  order  to  implement  a  computer  based  decision 
aiding  system. 

The  two  other  goal  parameters,  referring  to  formal 
and  informal  organization  structure,  are  invoked  when  the 
user  responds  that  either  or  both  of  these  structures  are 
not  available.   When  this  answer  is  indicated,  production 
rules  for  FORSTRUC  and/or  UNKSTRUC  result  in  the  recommenda- 
tions for  the  use  of  either  line  and/or  centralized  structures 
are  made . 
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VII.   TUTORIAL 

A.   OBJECTIVES 

The  EMYCIN  system  was  designed  and  implemented  by  a 
research  group  at  Stanford  University,  Palo  Alto,  California. 
It  contains  the  essential  components  needed  to  create  and 
support  an  interactive  consultation  program.   These  essential 
components  are  the  consultation  program,  predicate  functions 
and  their  translations,  the  explanation  subprogram,  and  the 
question-answering  subprogram.   (This  last  feature  is  currently 
not  functioning  in  EMYCIN.)   The  subject  domains  of  the  program 
range  from  human  blood  disease  diagnosis  to  structural  analy- 
sis [Scott,  1979].   The  domain  of  the  prototype  program 
developed  in  this  paper  is  decision  support  system  charac- 
teristics and  is  named  "DECAIDS."   In  order  to  implement 
this  domain,  a  knowledge  base  was  created  and  fitted  into 
the  EMYCIN  format. 

The  objectives  of  the  tutorial  follow: 

1.  Introduce  the  computer-naive  user  to  the  EMYCIN 
system  and  the  DECAIDS  program. 

2.  Provide  users  with  the  required  background  and 
documentation  in  order  to  further  develop  DECAIDS  or 
develop  a  unique  program  of  their  own. 

3.  Demonstrate  the  basic  features  of  a  knowledge  base 
system  through  the  use  of  a  very  simple  prototype  system. 


55 


4.  Introduce  the  INTERLISP  programming  language  and 
provide  users  with  sufficient  information  concerning  its 
syntax  and  functions  for  use  with  the  DECAIDS  program. 

5.  Produce  an  interactive  system  which  will  provide 
managers  with  recommended  decision  aid  characteristics  based 
upon  their  individual  organization  structure  and  environment. 

The  first  and  second  objectives  are  related  and  will 
provide  users  with  the  more  basic  concepts  involved  in 
producing  a  working  system.   It  is  assumed  the  user  does  not 
possess  a  background  in  computer  science  and  every  effort 
will  be  made  to  explain  these  concepts  in  an  understandable 
manner. 

This  tutorial  is  intended  to  provide  an  introduction  to 
the  use  of  INTERLISP.   The  documentation  contained  in  the 
tutorial  and  Appendices  F  and  G  is  intended  to  furnish  users 
with  sufficient  knowledge  of  INTERLISP  so  that  they  can  work 
with  the  DECAIDS  program. 

Finally,  the  use  of  the  prototype  DECAIDS  program 
demonstrates  knowledge  base  features  and  provides  the 
basis  for  the  fifth  objective.   It  is  anticipated  that  the 
DECAIDS  program  will  be  greatly  expanded  and  improved  by 
future  users. 

B.   KNOWLEDGE  BASE  SYSTEMS 

The  building  blocks  of  the  knowledge  base  are  contexts, 
parameters,  goal-parameters,  and  production  rules.   The  first 
step  in  the  creation  of  a  knowledge  base  is  the  creation  of 
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the  tree  structure  which  represents  the  subject  domain. 
(Figure  VI-1  provides  the  logical  tree  structure  or  knowledge 
base  of  the  DECAIDS  program.)   The  selection  of  the  subject 
creates  the  root-context  for  the  context  tree.   The  root 
context  will  have  one  or  more  goal-parameters  which  represent 
the  ultimate  "recommendations"  to  be  inferred  from  production 
rules.   The  various  branches  of  the  context  tree  are  repre- 
sented by  parameters  used  to  describe  the  subject  domain  of 
the  tree.   The  ultimate  objective  is  to  write  a  set  of 
production  rules  which  relate  parameters  with  appropriate 
goal-parameters.   Goal-parameters  can  be  defined  as  those 
parameters  which  are  concluded  from  the  production  rules. 
This  objective  is  accomplished  by  writing  questions  about 
the  system  parameters  in  natural  language  (i.e.,  English). 
The  responses  to  these  questions  will  constitute  the  infor- 
mation contained  in  the  knowledge  base. 

The  system  parameters  must  be  declared  next.   Section  C 
of  this  chapter  and  Appendix  D  contain  definition  and  examples 
of  the  various  parameter  properties.   These  properties  must 
be  provided  by  the  system  designer  when  the  parameters  are 
declared  (entered  on  the  computer  system) . 

The  knowledge  base  system  production  rules  are  written 
in  the  following  format: 
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If:   parameter,  =  value  ,  and 

parameter-  =  value 2  and 

parameter   =  value 
r        m        m 

Then:   goal-parameter..  =  goal-value   (cf)  ,  and 

goal-parameter   =  goal-value   (cf)  . 

&r        n   °         n  *■  * 

Each  value  for  the  goal-parameters  will  have  its  own  certainty 
factor  (cf)  assigned.   A  certainty  factor  is  a  relative  weight 
based  upon  probabilistic  reasoning  by  the  expert  who  provides 
the  knowledge  base.   In  EMYCIN/DECAIDS ,  these  certainty  factors 
range  from  -1.0  to  1.0  in  increments  of  0.1. 

The  successful  construction  of  a  knowledge  base  depends 
greatly  on  the  fact  that  conditional  statements  are  related 
to  all  of  the  declared  parameters.   These  conditional  state- 
ments are  actually  a  set  of  backward- chaining  rules  which 
eventually  conclude  the  declared  goal-parameter (s) .   For 
example,  one  of  the  DECAIDS  program  current  goal-parameters 
is  "DECAIDS."   Therefore,  production  rules  must  eventually 
assign  "DECAIDS"  some  value,  i.e., 

If:   Parameter  X  is  Value  Y 

Then:   Conclude  "DECAIDS"  equals  (recommendation). 

The  value  of  parameter  X  is  provided  to  the  program  during 
the  interactive  session.   The  recommendations  for  this 
particular  goal -parameter  (DECAIDS)  consist  of  the  four 


parameters  called  TYPSYS ,  OUTPUT,  INSTALL,  and  TRG .   These 
parameters  are  more  thoroughly  explained  in  the  preceding 
chapter. 

The  successful  implementation  of  this  type  system  depends 
upon  providing  a  chain  of  reasoning  that  will  "find"  parameter 
values  which  lead  to  the  "selection"  of  desired  goal -parameter 
values.   This  can  be  accomplished  by  first  writing  the  con- 
ditional statements  related  to  parameters  that  will  conclude 
the  goal-parameters  in  English.   From  this  format  these  rules 
can  easily  be  transposed  into  the  INTERLISP  language.   The 
EMYCIN  monitor  selects  the  order  in  which  conditional  state- 
ments will  be  processed.   The  system  designer  can  control  the 
direction  of  the  interactive  session  by  ordering  the  parameters 
(of  the  context's  MAINPROPS  property)  in  a  manner  which  makes 
the  session  flow  easily.   This  is  accomplished  because  the 
system  asks  its  questions  (PROMPTS)  in  the  same  order  that 
these  MAINPROPS  are  listed. 

C.   SYSTEM  PROPERTIES 

The  following  properties  are  used  in  the  EMYCIN/DECAIDS 
program.  They  are  used  to  implement  system  additions  after 
the  appropriate  production  rules  have  been  written. 

1.   Contexts 

The  knowledge  base  is  centered  around  the  "object- 
attributed-value"  triples.   The  object  portion  of  this  triple 
is  the  context.   A  context  is  some  entity  made  up  of  related 
parameters.   Each  system  that  is  constructed  must  have  at 
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least  one  context  (or  root)  which  is  the  subject  for  that 
system. 

In  DECAIDS,  the  context  is  "ORGANIZATION."   The 
relative  simplicity  of  the  current  DECAIDS  knowledge  base 
lends  itself  to  the  use  of  this  single  context.   In  more 
complex  subject  domains,  it  may  become  necessary  to  organize 
system  attributes  into  multiple  contexts.   For  example, 
EMYCIN  uses  PERSON  (the  root  context) ,  CULTURES  (the  results 
of  infectious  cultures) ,  and  ORGANISMS  (the  types  of  organisms 
obtained  from  cultures  and  treated  which  is  to  be  prescribed) 
[Davis,  1977].   System  designers  must  decide  a  priori ,  based 
upon  system  complexity,  how  parameters  are  to  be  organized 
into  contexts.   It  is  noteworthy  to  mention  that  with  proper 
organization,  even  relatively  large  systems  can  be  frequently 
organized  under  one  context.   However,  if  multiple  contexts 
are  used,  they  must  be  arranged  in  a  context  tree  which 
allows  the  production  rules  to  refer  to  parameters  of  more 
than  one  related  context.   This  is  accomplished  with  the 
context  properties  ASSOCWITH  and  OFFSPRING.   These  properties 
are  lists  of  ancestors  and  descendent  context  types,  respec- 
tively. 

Contexts  are  declared  in  a  manner  similar  to  that 
used  to  declare  parameters.   (This  is  true  because  contexts 
are  also  parameters.)   These  specific  procedures  are  dis- 
cussed in  the  following  section. 

The  primary  properties  which  must  be  declared  for 
contexts  are:   MAINPROPS ,  TRANS,  PROPTYPE ,  TYPE,  RULETYPE , 
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and  GOALS.   Other  properties,  included  as  Appendix  D,  are 
necessary  for  describing  systems  which  are  more  complex 
than  DECAIDS.   These  names  are  system  names  and  are  explained 
as  follows. 

MAINPROPS  -  These  are  the  main  parameters  which 
describe  a  context.   These  parameters  are  declared  as  a  list 
and  are  used  to  "trace"  or  define  the  context.   The  consul- 
tation session  includes  an  interactive  phase  where  these 
MAINPROPS  are  asked  of  the  user.   User  responses  will  invoke 
the  appropriate  production  rules  to  produce  the  consultation 
recommendations.   The  order  in  which  these  parameters  are 
listed  in  the  property  of  MAINPROPS  assists  in  providing  a 
more  logical  or  "coherent"  consultation  for  the  user. 

TRANS  -  This  property  is  the  literal  translation  of 
the  context  (or  parameter) .   This  definition  describes  how 
that  context  will  be  translated  in  the  program.   In  DECAIDS, 
the  TRANS  of  the  context  ORGANIZATION  is  "the  organization." 

PROPTYPE  -  This  property  is  used  by  the  system  to 
identify  to  which  context  a  particular  parameter  belongs. 
DECAIDS  contains  one  PROPTYPE  for  ORGANIZATION,  PROP-ORG. 

TYPE  -  This  property  is  the  name  used  to  identify 
contexts.   For  example,  successive  consultations  involving 
the  context  ORGANIZATION  will  be  titled  "ORGANIZATION  1, 
ORGANIZATION  2,  ORGANIZATION.  .  .". 

RULETYPE  -  This  is  a  list  of  the  rules  which  must  be 
searched  in  order  to  find  a  particular  parameter.   ORGANIZATION 
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currently  has  only  one  ruletype,  ORGRULES ,  which  contains 
all  rules  to  determine  the  goal-parameters.   This  name  was 
chosen  to  stand  for  "organization  rules." 

GOALS  -  This  is  a  list  of  goal-parameters  which  are 
applicable  to  the  context.   More  than  one  goal  is  allowable. 
This  allows  for  the  more  complex  systems  to  be  represented 
by  single  contexts.   Current  goal-parameters  for  ORGANIZATION 
are  DECAIDS,  UNKSTRUC,  and  FORSTRUC. 
2 .   Parameters 

Parameters  are  defined  as  attributes  which  describe 
a  given  context.   In  the  knowledge  base,  "object-attribute- 
value"  triple,  parameters  are  the  attributes.   These  attri- 
butes may  be  thought  of  as  questions  to  be  asked  (of  the  user 
or  the  system)  that  describe  the  context.   For  example,  the 
system  designer  will  ask  the  following  type  of  questions, 
"Is  the  'parameter'  of  the  'context'  a  'value'?"   The  values 
correspond  to  appropriate  answers  to  the  designer's  questions, 
These  are  pre-specif ied  (if  appropriate)  by  declaring  them 
in  the  EXPECT  property  of  the  particular  parameter  and  are 
explained  later  in  this  section. 

The  use  of  parameters  in  production  rules  has  been 
discussed.   Parameters  are  contained  in  the  various  lists 
with  names  of  the  form  PROP- type.   This  form  indicates  a 
prompt  which  the  user  will  answer.   These  lists  are  further 
collected  into  either  PROPGROUPS  or  AUXPROPGROUPS .   PROP- 
GROUPS  initially  contain  the  reserved  work  PROP-VAL,  which 
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is  the  PROPTYPE  for  contexts,  and  eventually  contain  each 
parameter  group  declared  in  the  context's  PROPTYPE  property. 
(Keep  in  mind  that  contexts  are  declared  in  the  same  manner 
as  parameters.)   AUXPROPGROUPS  are  lists  of  auxiliary 
parameters  which  serve  varying  purposes.   The  most  useful  of 
these  purposes  is  defining  a  RULEGROUP.   A  RULEGROUP  will 
be  explained  in  the  following  section. 

The  most  frequently  used  parameter  properties  in 
the  DECAIDS  system  are:   TRANS,  PROMPT,  EXPECT,  REPROMPT,  and 
LAB DATA. 

TRANS  -  This  is  the  literal  translation  of  the 
parameter.   TRANS  is  declared  in  the  same  manner  as  contexts. 

PROMPT  -  This  property  is  the  natural  language 
text  question  which  is  asked  of  the  user  concerning  each 
parameter.   Care  should  be  taken  when  composing  prompts 
so  that  the  consultation  dialogue  makes  sense  to  the  user. 
(The  context's  MAINPROPS  property  can  be  used  to  assist  in 
making  the  consultation  flow  smoothly  and  logically. 
Parameter  PROMPTS  are  asked  in  the  same  order  the  parameters 
are  listed  in  the  MAINPROPS.) 

EXPECT  -  These  are  the  accepted  or  "expected" 
responses  to  the  PROMPTS.   The  specific  values  may  be 
supplied  by  either  the  system  designer  or  user.   In  order 
to  specify  that  anything  is  an  appropriate  answer,  the  word 
"ANY"  should  be  entered  as  the  EXPECT  value  of  that  parameter 
If  a  parameter  has  a  PROMPT,  it  must  also  have  an  EXPECT 
value . 
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REPROMPT  -  These  are  additional  natural  language 
text  statements  which  are  used  to  further  explain  the 
question  asked  by  parameter  PROMPTS.   They  are  of  great  value 
to  the  designer  and  user  because  they  can  remove  ambiguity 
concerning  PROMPT  meanings.   They  automatically  list  the 
accepted  responses  which  the  system  will  recognize.   This 
property  is  invoked  when  the  user  responds  with  a  question 
mark  when  asked  a  parameter  PROMPT. 

LABDATA  -  This  property  is  a  system  key  that  indi- 
cates that  the  user  will  provide  a  value  for  that  parameter. 
This  is  done  by  entering  "T"  as  the  value  for  LABDATA. 

An  example  of  these  various  properties  is  provided 
for  the  following  DECAIDS  parameter: 


FORMAL:     (Parameter  name) 

TRANS:      (The  organization's  structure) 

PROMPT:     (The  formal  structure  of  the  organization 
can  be  defined  as  either  line,  staff, 
matrix,  functional,  or  not  available.   If 
further  explanation  of  these  terms  is  need- 
ed, type  a  question  mark.   What  is  the 
organization's  formal  structure?" 

EXPECT:     (Line,  Staff,  Functional,  Matrix,  Not 
Available) 

LABDATA:    T 

REPROMPT:   (Line-emphasizes  direct  chains  of  authority 
and  unity  of  command.   Staff -  includes  an 
informational  and  advisory  staff  to  assist 
and  guide  operational  personnel.   Functional 
arranges  personnel  by  functional  activity 
such  as  logistics,  communications,  etc. 
Matrix-draws  personnel  from  across  depart- 
mental lines.) 
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3 .   Rulegroups 

All  rules  must  be  assigned  to  groups  called  rule- 
groups  prior  to  being  declared  (entered  on  the  system). 
If  no  rulegroup  is  defined,  the  rules  will  not  compile. 
Rulegroups  are  determined  by  the  type(s)  of  contexts  to  which 
a  rule  may  apply.   Generally,  a  rule  is  applicable  to  the 
lowest  context  in  the  tree  whose  parameters  appear  in  its 
PREMISE  or  ACTION.   The  group  for  the  rule  must  be  in  the 
RULETYPES  property  of  the  applicable  context  type(s).   In 
most  cases,  the  RULETYPES  property  will  be  a  list  of  a  single 
group.   All  rulegroups  are  members  of  the  parameter  group 
called  ALLNAMES.   The  use  of  ALLNAMES  is  covered  in  the 
GETPARMS  section  of  this  chapter.   Before  entering  rules, 
it  is  necessary  to  define  and  initialize  all  rulegroups  which 
are  named  "typeRULES."   The  procedure  for  accomplishing  this 
is  to  type  "SET (typeRULES  NIL)"  and  then  define  the  group 
by  the  GETPARMS  routine.   (The  word  type  in  lower  case 
letters  refers  to  the  specific  type  used.   In  DECAIDS,  the 
rulegroup  is  called  ORGRULES.   This  stands  for  organization 
rules . ) 

Rulegroups  have  the  following  properties: 

CONTEXT  -  This  is  the  list  to  which  rules  of  this 
type  apply. 

SVAL  -  This  property  tells  how  to  translate  the 
reserved  word  "CNTXT"  in  rules  of  this  type. 

CTRANS  -  This  is  a  phase  in  English  (a  translation) 
describing  what  context  types  the  rules  apply  to.   This 
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translation  fills  in  the  blank  in  the  EMYCIN  system  phrase, 

"this  rule  applies  to  . "   This  explanation  precedes 

actual  rules  when  rules  are  actually  printed  by  the 
PRINTRULES  routine.   The  use  of  this  routine  is  explained 
in  this  next  section  of  this  chapter. 

D.   GETTING  STARTED 

1.  Accessing  the  ARPANET 

The  DECAIDS  system  currently  resides  on  a  computer 
at  the  Information  Sciences  Institute  of  the  University  of 
Southern  California.  Access  to  the  system  may  be  accomplished 
through  the  ARPANET.  The  different  uses  and  further  back- 
ground material  on  the  ARPANET  are  not  contained  in  this 
paper.  The  specific  procedures  used  to  access  the  DECAIDS 
program  on  the  ARPANET  are  contained  in  Appendices  F  and  G. 

2.  GETPARMS 

The  EMYCIN  program  contains  a  routine,  GETPARMS, 
which  is  used  to  declare  all  contexts,  parameters,  and  rule 
groups.   After  logging  onto  the  ARPANET  and  entering  the 
EMYCIN  executive  file,  EMYCIN.EXE,  (as  discussed  in  Appendix  F) 
the  procedures  outlined  in  Appendix  G  are  used  to  enter, 
edit,  or  delete  parameters. 

The  most  frequently  used  parameter  properties  used 
in  DECAIDS  are:   TRANS,  EXPECT,  PROMPT,  LABDATA,  and 
REPROMPT ,  as  discussed  previously.   The  most  important  of 
these  properties  is  PROMPT  as  it  "prompts"  the  natural 

language  question  which  will  be  asked  of  the  user  concerning 
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a  particular  parameter.   The  PROMPT  should  be  written  in 
such  a  manner  as  to  present  a  logical  dialogue  to  the  user. 
The  LABDATA  property  is  a  system  key  which  indicates  that 
the  appropriate  value  of  a  parameter  must  be  obtained 
from  the  user. 
3.   GETRULES 

The  GETRULES  routine  is  used  to  declare  system  rules 
after  the  various  parameters  have  been  entered.   These  system 
rules  are  written  to  arrive  at  a  final  goal  and  thereby 
conclude  the  value  of  a  parameter.   Appendix  G  contains  the 
specific  procedures  to  be  followed  when  using  GETRULES. 

Rules  are  entered  in  two  parts,  PREMISE  and 
ACTION.   Following  the  final  parentheses  in  the  ACTION 
clause,  the  rule  is  checked  for  syntactic  validity  and  an 
error  message  is  returned  if  an  error  is  detected.   If  the 
subject  of  the  rule  cannot  be  deduced,  the  user  is  asked  to 
confirm  the  rule  group.   The  proper  response  is  "Y"  (yes) 
if  the  offered  rulegroup  is  correct  or  the  rule  group  is 
entered. 

There  is  a  useful  feature  that  may  be  used  in  con- 
junction with  either  GETRULES  or  GETPARMS .  If,  during  the 
course  of  entering  rules  or  parameters,  the  user  discovers 
the  necessity  of  returning  to  the  other  routine,  he  may  do 
so  by  typing  "RULES"  (in  GETPARMS)  or  "PARAMETER"  (in 
GETRULES) .  This  facilitates  writing  a  set  of  parameters 
and  then  calling  GETRULES  to  declare  the  relevant  rules. 
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The  recommended  format  for  entering  rules  is  the 
INTERLISP  syntax.   A  "terse"  English  form  is  available  but 
requires  much  more  typing.   Additionally,  in  preparing  the 
rules  via  the  INTERLISP  syntax,  the  concept  of  writing  a 
set  of  rules  to  produce  backward- chaining  (which  drives  the 
direction  of  a  consultation)  becomes  more  apparent.   Most 
of  the  premise  clauses  will  be  calls  to  the  predicate 
functions  SAME,  NOTSAME ,  or  KNOWN.   These  can  be  written  as: 

INTERLISP:  terse  meaning: 

(SAME  CNTXT  parm  value)       parm  =  value 

or 

(NOTSAME  CNTXT  parm  value)     parm  /  value 

The  following  example  is  from  DECAIDS: 

(SAME  CNTXT  STRESS  LOW)        STRESS  =  LOW 

Similarly,  the  numeric  predicates  can  be  entered  as: 

INTERLISP: 

GREATERP*   (VAL1  CNTXT  parm)  number) 

Terse  meaning: 

parm  value  =  number 

No  numeric  predicate  functions  are  currently  used  in  DECAIDS. 

ACTION  statements  will  contain  functions  that  con- 
clude about  one  or  more  of  the  context-parameter-value 
triples.   A  certainty  factor  (cf)  for  the  triple  is  specified 
in  the  rule's  ACTION.   This  certainty  factor  will  be  modified 
by  the  certainty  of  the  rule's  PREMISE.   The  function  "$AND" 
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sets  the  reserved  word  TALLY  to  the  certainty  of  the 
PREMISE,  defined  to  be  the  minimum  of  the  values  returned 
by  evaluating  the  PREMISE  clauses  (only  SAME  and  THOUGHTNOT 
return  numbers).   The  conclusion  may  be  written  as: 

(CONCLUDE  CNTXT  parm  value  TALLY  cf) 
parm  =  value  (cf) 

The  following  example  is  from  DECAIDS : 

(CONCLUDE  CNTXT  TYPSYS  REAL-TIME  TALLY  800) 
type  system  =  real-time  with  a  certainty  of  0.8 

The  certainty  factors  are  actually  written  in  the  range 
-1000  to  1000.   This  range  represents  the  -1  to  1  mentioned 
earlier.   The  system  writer  should  use  the  numbers  in  the 
preceding  range  in  a  call  to  CONCLUDE  or  other  ACTION 
functions . 

The  function  DO-ALL  is  used  to  conclude  about  the 
several  parameters  which  comprise  any  multi-valued  parameter, 
such  as  DECAIDS.   Once  a  goal-parameter  has  been  traced, 
the  rule  calling  for  PRINTCONCLUSIONS  will  be  evaluated  true 
and  an  output  statement  will  be  generated.   (See  rule  001  in 
Appendix  A. ) 

4.   Declaring  the  Treeroot  and  the  RULEGROUP  Type 

Once  it  has  been  decided  what  the  system  objective  is, 
the  context  tree  is  designed  and  filled  in.   It  is  necessary 
to  make  the  following  system  declaration.   From  the  EMYCIN  . 
EXE,  (not  GETPARMS  or  GETRULES)  the  "SET"  command  is  used 
to  define  the  context  tree  root  in  the  following  format: 
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_SET(  TREEROOT  rootcontxt) 

_SETQ(ROOTTYPE  (GETP  ' rootcontext • TYPE) ) . 

An  example  of  the  procedure  using  a  DECAIDS  example  follows: 

_SET(TREEROOT  ORGANIZATION) 
_SETQ(ROOTTYPE  (GETP  'ORGANIZATION 'TYPE) ) . 

The  "_"  is  the  EMYCIN.EXE  prompt.   Upper  or  lower  case  letters 
may  be  used  to  set  the  rootcontext  name.   This  function 
should  be  performed  along  with  "SETting"  the  RULEGROUP : 

_SET(ruletype) 

In  DECAIDS: 

_SET(ORGRULES) . 

The  preceding  examples  contain  capital  letters  because 
capitals  were  used  throughout  the  DECAIDS  program. 

In  order  to  save  items  such  as  the  treeroot  and 
rulegroup  declarations,  it  is  necessary  to  edit  the 
CHANGESCOMS  files.   This  file  is  a  list  delineating  what 
should  be  stored  on  the  CHANGES  current  program  file.   With 
the  command  "MF  CHANGES,"  the  editions,  additions  and 
deletions  to  GETPARMS  and  GETRULES  are  saved.   However,  the 
following  procedure  must  be  used  to  save  the  treeroot  and 
rulegroup.   (The  "__"  is  the  EiMYCIN  prompt  and  the  "*"  is  the 
INTERLISP  prompt.)   The  following  is  an  example  from  DECAIDS: 


70 


_EV  CHANGESSCOMS  (This  command  edits  the 

variables  that  follow.) 

*(-l  TREEROOT)  ("-1"  means  insert  the 

following  before  the  first 
element  in  the  list.) 

*SET (TREEROOT  ORGANIZATION) 

*SETQ(ROOTTYPE  (GETP  'ORGANIZATION 'TYPE) ) 

*SET(ORGRULES) 

*OK  (This  exits  the  editor  and 

the  file  must  be  saved  with 
MF  CHANGES.) 

5 .   Saving  Changes  to  Rules  and  Parameters  and  Deleting 
Changes 

Each  update,  addition,  deletion,  or  edit  to  the 

system  knowledge  base  is  referred  to  as  a  CHANGE.   Each  CHANGE 

requires  the  complete  recopying  of  the  entire  program.   The 

command  used  to  save  these  changes  is  "MF  CHANGES."  A  new 

file  is  created  when  the  user  enters  the  system  each  time. 

This  file  is  comprised  of  all  previous  information  that  has 

been  entered  plus  the  new  entries  to  the  knowledge  base. 

Accordingly,  there  is  no  need  to  keep  multiple  copies  of 

the  previous  CHANGES  after  creating  a  file  of  new  CHANGES. 

These  "old"  copies  may  be  deleted  by  using  the  command, 

"DEL  CHANGES. . (number  to  be  deleted)."   If  no  number  is 

specified,  the  lowest  number  version  (or  oldest)  will  be 

deleted.   (During  the  login  procedures,  the  entire  file 

status  is  presented  to  the  user.   The  CHANGES  file  will 

indicate  exactly  what  number  the  user  currently  has  in  use.) 

Occasional  naming  conflicts  have  occurred  with  the  operating 
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systems,  TENEX  and  TOPS- 20,  resulting  in  unwanted  change 
deletions.   It  is  therefore  recommended  that  the  user 
maintain  at  least  two  or  three  changes  as  "insurance" 
against  losing  everything  that  has  been  entered. 

6.  Loading  CHANGES 

In  order  to  run  a  consultation,  it  is  necessary  to 
concatenate  the  knowledge  base  with  EMYCIN.EXE.   This  is  done 
by  the  following  command,  "LOADEM  CHANGES."   The  file  which 
is  currently  in  use  has  this  command  included  in  the  executive 
login  procedures  and  therefore  does  not  have  to  be  entered  by 
the  user. 

7 .  Displaying  Parameters 

The  following  PRINTPARMS  command  should  be  used  to 
display  all,  or  part  of  the  parameters  entered  in  the  know- 
ledge base: 

"_PRINTPARMS(parm  sort .by . group  linelength  file) 

where  parms  may  be  a  list  of  parameters,  a  list  of  parameter 
groups,  a  single  parameter  group,  or  NIL  meaning  all  param- 
eters.  The  term  "sort .by .group"  is  T  or  NIL.   T  means  that 
an  alphabetical  index  is  printed  first,  showing  which  group 
each  parameter  belongs  in.   NIL  indicates  that  the  parameters 
are  listed  in  alphabetical  order  regardless  of  the  group  to 
which  they  belong.   Linelength  is  the  length  of  the  line  to 
be  used,  i.e.,  72,  78,  or  SO  spaces.   File  is  the  name  of 
the  file  in  which  to  write  the  information.   If  T  is  used, 
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the  parameters  will  be  written  to  the  terminal.   The 
PRINTPARMS  command  may  be  used  within  the  DRIBBLE  command 
(which  is  explained  in  Section  9  of  this  chapter)  to  write 
the  parameters  into  a  separate  file.   An  example  of  this 
command  follows: 

_PRINTPARMS(NIL  T  72  T) . 

8.  Displaying  Rules 

The  procedure  for  displaying  knowledge  base  rules  is 
similar  to  the  PRINTPARMS  command.   The  command  is: 

_(PRINTRULES  rules  mode). 

In  this  command,  rules  is  a  list  of  rules,  a  rule  group, 
and  mode  indicates  how  the  rules  are  to  be  printed.   Mode 
includes  these  options : 

B  -  both  in  English  and  INTERLISP 

E  -  in  English 

L  -  in  INTERLISP 

J  -  for  justification  which  permits  inclusion 
of  author's  name. 

9.  Creating  a  File  in  the  EMYCIN.EXE 

In  order  to  create  a  file  of  the  knowledge  base 
contents,  the  following  sequence  of  commands  is  used: 
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_DRIBBLE( filename)    where  the  filename  is  of  the  user's 

choice  and  DRIBBLE  opens  a  type- 
script for  the  filename. 

_PRINTPARMS  (or  PRINTRULES) 

_DRIBBLE   The  last  DRIBBLE  command  closes  the  file. 

10 .   Running  a  Consultation 

Appendix  F  contains  the  specific  procedures  that 
are  required  to  run  a  consultation.   This  section  contains 
supplementary  information  that  is  not  found  in  that  appendix. 

The  following  special  options  are  available  when 
running  a  consultation,  "FT  1,  2,  3,  4,  or  carriage  return 
"(no  options)."   FT  stands  for  fault  trace.   The  numbers  that 
follow  FT  indicate  the  level  of  the  "trace"  desired  with  1 
being  the  lowest  and  4  being  the  highest  degree  of  fault, 
or  rule,  tracing.   Fault  trace  4  (FT4)  will  present  each 
rule  number  as  it  is  being  sought,  indicate  that  the 
FINDOUT  routine  is  tracing  the  appropriate  parameter,  and 
complete  with  the  FINISHED  routine  when  a  rule  has  been 
completely  traced.   Once  the  rule  is  evaluated  as  true,  this 
is  indicated  by  a  message  "RULE  (#)  SUCCEEDED." 

At  the  other  end  of  the  scale,  FT  1  will  show  those 
rules  which  have  succeeded  and  then  display  their  ACTION 
statements . 

The  user  can  request  the  following  special  features 
by  entering  one  or  more  of  the  following  options  with  spaces 
and  ending  with  a  carriage  return: 
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I   -      requests  instructions  to  be  printed. 

OLD  -     consider  a  previously-saved  case  (number(s) 
will  be  requested) . 

SAVE  -    create  and  save  file(s)  for  cases  discussed 
in  this  consultation. 

NOPR  -    do  not  print  out  old  questions  and  answers 
when  running  old  cases. 

SUMMARY  -  summarize  old  session  data,  rather  than 
printing  out  each  question  and  answer. 

UPDATE  -   update  old  session  with  new  information 

TER  -     enter  terse  mode. 

TAB  -     tabular  entry  mode . 


TS  - 
N  - 
QA  - 


write  out  a  typescript  file  of  consultation. 

(a  number)  reconsider  previously  saved  case  n 

enter  the  question/answer  module  immediately 
skipping  the  consultation  (currently  turned 
off  in  EMYCIN) .   The  terms  "case"  and 
"patient"  remain  from  the  original  EMYCIN 
system  referring  to  a  medical  consultation. 


The  following  instructions  are  printed  if  the  user 
responds  "Y"  when  asked  if  instructions  are  desired: 

Please  answer  the  following  questions,  terminating 
each  response  with  RETURN  (CR) .   To  correct  typing  errors, 
use  the  DELETE  key  to  delete  characters,  (ctrl)W  to 
delete  a  word  and  (ctrl) L  to  delete  the  whole  line. 

If  you  are  not  certain  of  your  answer,  you  may  modify 
the  response  by  inserting  a  certainty  factor  (a  number  from 
1  to  10)  in  parentheses  after  your  response.   Absolute 
certainty  (10)  is  assumed  for  every  unmodified  answer.   It 
is  likely  that  some  of  the  following  questions  cannot  be 
answered  with  certainty.   You  may  change  an  answer  to  a 
previous  question  in  two  ways.   If  the  program  is  waiting 
for  a  response  from  you  (that  is,  has  typed  "**"),  enter 
CHANGE  followed  by  the  number (s)  of  the  question(s)  whose 
answers  will  be  altered.   You  may  also  change  a  previous 
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answer  at  any  time  (even  when  the  program  is  not  waiting 
for  a  response  from  you)  by  typing  (ctrl)F  (Fix),  which 
will  cause  the  program  to  interrupt  its  compilation  and 
ask  what  you  want  to  change.   If  the  response  to  (ctrl)F 
is  not  immediate,  try  typing  the  RETURN  key  in  addition.) 
Try  to  avoid  going  back  because  the  process  requires 
reconsidering  the  case  from  the  beginning  and  therefore 
may  be  slow.   Note  that  you  may  also  enter  UNK  (for 
unknown) .   If  you  do  not  know  the  answer  to  a  question, 
?  if  you  wish  to  see  a  more  precise  definition  of  the 
question  or  some  examples  of  recognized  responses,  ?? 
if  you  want  to  see  all  recognized  responses,  the  word 
RULE  if  you  would  like  to  see  the  decision  rule  which 
has  generated  the  questions  being  asked,  the  word  WHY 
if  you  would  like  to  see  a  more  detailed  explanation  of 
the  question,  or  the  letters  QA  if  you  would  like  to 
interrupt  the  consultation  in  order  to  ask  questions 
regarding  the  decision  made  so  far  in  the  consultation. 
If  you  are  ever  puzzled  about  what  options  are  available 
to  you  during  a  consultation,  enter  the  word  HELP  and  a 
list  of  options  will  be  listed  for  you. 

Sample  response  (user  input  follows  M**M) 
Does  the  patient  have  a  risk  factor 
for  tuberculosis? 

One  or  more  of  the  following  are  considered 
risk  factors  for  TB :   A)  Positive  PPD  (5TU) , 
B)  History  of  close  contact  with  a  person 
having  active  TB,  C)  Household  member  with 
a  past  history  of  active  TB ,  D)  Chest  x-ray 
showing  apical  scarring,  E)  Granulomas 
seen  on  biopsy  of  any  organ  tissue. 
Expected  responses  are:   YES   NO 
Enter  HELP  for  user  options. 
**  YES 

SUMMARY: 

(Type  ctrl-0  to  abort  printout) 

UNK  -  answer  not  known 

?   -  rephrases  the  question  and  gives  examples 

of  recognized  responses 
??   -  prints  a  list  of  all  recognized  responses 
RULE  -  prints  the  current  decision  rule 
QA  -   program  enters  question-answer  mode 
CHANGE  -  go  back  and  re-request  answer  to  question 

number  §   performance.   Your  comments  will  be 

forwarded  to  those  in  charge  of  the  MYCIN 

program. 
WHY  -  gives  high-level  explanation  of  the  current 

reasoning  chain  that  provoked  this  question. 
HOW  #  -  explain  HOW  the  system  will  achieve  a  goal 

referred  to  by  number  I  in  a  previous  explanation 
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EXPLAIN  -  provides  a  more  detailed  explanation  of  a 
previous  answer  given  by  a  WHY  command. 

FORGET  -  resets  the  explanation  of  the  reasoning 
chain  back  to  the  lowest  level,  as  if  you 
never  used  the  WHY/EXPLAIN  commands. 

STOP  -  halts  the  program,  saving  the  current  case 
on  a  disk  file,  retrievable  at  a  later  date. 

HELP  -  prints  this  list.   [Scott,  1979]. 

Once  the  user  has  answered  the  system  queries  con- 
cerning instructions  and  options,  the  consultation  will 
begin.   When  a  goal-parameter  is  found,  the  conclusion  rule, 
currently  called  PRINTCONCLUSIONS ,  will  be  triggered  and  the 
consultation  ended.   An  example  consultation  is  contained 
in  Appendix  C.   Fault  trace  4  (FT  4)  was  selected  for  this 
sample  consultation. 

11.   INTERLISP  EDITOR 

.  Chapter  Nine  of  the  INTERLISP  Reference  Manual  fully 
describes  the  editor  used  with  the  DECAIDS  program  [Teitelman, 
1974].   The  editor  is  entered  from  the  EMYCIN.EXE  by  typing 
"E"  and  may  be  reached  from  GETPARMS  or  GETRULES  in  order 
to  change  parameters  or  rules.   The  following  is  a  short 
list  of  the  most  often  used  editor  commands: 

n      -  (n  is  a  positive  integer)  move  to  the 

nth  element  of  the  list  where  the  element 
is  a  parenthetical  expression. 

p      -  print  the  current  expression,  used  with 
GETPARMS  or  GETRULES. 

-n  -  move  to  the  nth  element  from  the  end. 

(-n  X)  -  insert  X  after  the  current  element. 

B  X  -  insert  X  before  the  current  expression. 

:  -  delete  the  current  expression. 
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:  X    -  replace  the  current  expression  with  X. 
OK     -  ends  editing. 

The  "MF  CHANGES"  command  is  used  to  save  all  the  editing  which 
has  been  done . 

12.   Miscellaneous  DECAIDS  Notes 

The  following  notes  are  included  as  information  that 
applies  to  the  DECAIDS  program. 

The  INTERLISP  compiler  compiles  upper  and  lower  case 
letters  differently.   Either  may  be  used  to  fill  a  knowledge 
base.   For  example,  "DECAIDS"  will  compile  differently  than 
"decaids"  and  subsequent  use  in  rules  will  result  in  an  error 
message  stating  that  there  are  not  rules  to  conclude  one  or 
the  other.   Because  of  this  problem,  DECAIDS  was  entered  on 
the  machine  in  all  capital  letters. 

The  system  permits  a  consultation  user  to  respond 
with  "unknown"  to  a  request  for  information  which  is  not 
known  to  the  user.   This  "UNK"  means  that  the  certainty  factor 
for  the  rule  should  be  set  to  less  than  .2,  the  system's 
arbitrary  limit  for  acceptable  knowledge  about  a  parameter. 
Therefore,  if  the  system  writer  desires  to  provide  some  other 
certainty  factor  about  an  unknown  condition,  he  must  offer  a 
substitute  response  for  "UNK"  in  the  expect  values. 
"NOTAVAILABLE"  was  the  choice  used  in  DECAIDS. 

Rule  035  is  the  print  statement  for  the  goal- 
parameter  UNKSTRUC.   If  UNKSTRUC  was  not  known,  then  a 
recommendation  was  made  about  the  informal  organization 
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structure  to  be  recommended.   If  UNKSTRUC  was  known,  no 
output  was  necessary.   To  "turn  off"  the  output,  even  though 
UNKSTRUC  had  been  traced,  the  HEADER  in  the  PRINTCONCLUSIONS 
function  (Appendix  E)  was  left  at  NIL. 

In  rule  034,  a  parameter  in  the  rule  PREMISE  is  also 
used  in  the  ACTION.   In  the  parameter's  USED-BY  property  (a 
system  property  not  used  by  the  designer)  the  note 
SREFMARK  34  appears.   This  means  that  the  parameter  is  in 
the  PREMISE  and  ACTION  of  rule  034  and  is  a  system  flag  to 
prevent  various  search  and  circularity  problems. 

The  parameter  property  REPROMPT  is  used  to  locate 
the  text  presented  to  the  consultation  user  if  and  when  he 
responds  with  a  "?"  for  an  expected  parameter  value.   The 
system  designer  includes  further  explanation  of  expected 
values  or  the  parameter  definition  in  the  REPROMPT. 

The  "WHY"  response  to  a  question  rather  than  an 
allowed  expected  value  produces  an  explanation  of  the 
current  reasoning  chain  that  provoked  the  current  question. 
For  the  "WHY"  question  to  work,  the  system  writer  must 
previously  have  used  the  LISP  SET  command  to  set  the  value 
of  FINDBESTPARM.   This  value  is  used  to  an  EMYCIN  to  provide 
text  to  explain  the  reasoning  chain. 

If  intermediate  values  are  desired  to  be  known, 
not  necessarily  those  of  the  goal-parameters,  the  system 
writer  need  only  write  a  rule  to  "PRINTCONCLUSION"  for 
that  parameter. 
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VIII.   CONCLUSION 

It  was  the  purpose  of  this  thesis  to  demonstrate  the 
implementation  of  a  particular  domain  of  information  with 
the  Artificial  Intelligence  system  known  as  EiMYCIN.   The 
demonstration  illustrates  that  even  semi-structured  and 
subjective  domains  can  be  studied  using  AI  technology. 

The  domain  chosen  for  this  paper  was  that  of  managerial 
decision  aiding.   This  particular  subject  contains  many 
intuitive  thought  processes.   The  uncertainties  and  impre- 
ciseness  of  intuition  lends  itself  to  one  of  the  goals  of 
Artificial  Intelligence  which  is  the  capability  of  producing 
relevant,  acceptable  assertions  in  the  light  of  incomplete 
and  uncertain  information. 

Recommendations  are  offered  concerning  possible  exten- 
sion of  the  current,  single  context  knowledge  base  to  a 
multiple  context  tree.   Also,  the  motivations  for  further  AI 
work  are  established  and  a  summary  of  the  research  conducted 
and  accomplishments  are  presented.   The  motivations  mentioned 
represent  the  current  interest  for  continuing  Artificial 
Intelligence  research  and  development. 

A.   EXTENDING  THE  DECAIDS  CONTEXT  TREE 

The  current  domain  of  information  is  described  by  a 
single  context  and  related  parameters.   It  is  intended  to 
be  a  prototype  domain  for  a  decision  aiding  support  system 
and  an  example  of  how  to  structure  a  knowledge  base.   It  is 
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expected  that  the  knowledge  base  will  be  extended  to  include 
a  more  complex  context  tree  supporting  a  far  more  thorough 
treatise  of  the  decision  aiding  support  process.   The 
following  information  is  directed  toward  the  individual  who 
will  extend  the  current  knowledge  base. 

Prior  to  doing  any  coding  or  entering  of  any  rules  or 
parameters,  it  is  strongly  advised  (cf  1.0)  that  the  system 
goal(s)  be  explicitly  defined.   This  means  not  only  deciding 
that  the  system  is  to  provide  some  form  of  advice  but,  more 
specifically,  to  write  out  the  natural  (i.e.,  English) 
language  questions  which  will  be  used  to  trace  parameter 
values.   Entering  rules  and  parameters  into  the  DECAIDS 
knowledge  base  is  not  unlike  any  other  high-level-language 
coding  where  a  flowchart  of  operations  and  data  manipulation 
are  appropriate.   A  system  designer  is  reminded  that  the 
primary  emphasis  for  extending  a  knowledge  base  is  a  con- 
sistent line  of  questions  to  be  asked  in  order  to  trace 
parameter  values.   Eliminating  or  ignoring  the  requirement 
to  specify  the  questions  to  be  asked  can  only  lead  to 
confusion. 

When  to  define  a  context  or  multiple  contexts  may  present 
the  system  designer  with  some  confusion.   It  is  recommended 
that  the  designer  review  the  notes  on  backward-chaining  and 
the  concept  of  inferences.   This  information  (Chapter  VII) 
will  provide  the  necessary  background  for  constructing 
rules  which  terminate  in  the  determination  of  values  for 
parameters . 

» 
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Most  often  a  single  context  will  suffice  for  a  small  to 
medium  size  knowledge  base.   However,  to  fully  describe  the 
management  decision  aiding  characteristics  about  some  subject 
(i.e.,  electronic  warfare,  major  procurement  systems,  etc.) 
may  require  a  more  complete  context  tree.   The  subjects 
that  become  contexts  are  those  that  cover  areas  of  informa- 
tion which  will  always,  or  nearly  always,  be  used  to  define 
the  value  of  the  root,  goal-parameters.  The  infectious  blood 
disease  domain  of  MYCIN,  for  example,  is  described  by  the 
following  contexts: 

PATIENT 
CULTURE 
ORGANISM 

Each  of  these  contexts  has  multiple  parameters  leading  to 
the  goal-parameter (s)  values.   The  management  domain  might 
include  contexts  such  as : 

DECISION 


TECHNOLOGY 


ENVIRONMENT 


TASK 


STRUCTURE 


ADMINISTRATIVE    TACTICAL 


or : 


DECISION 


ELECTRONIC  WARFARE     ASW    AIRBORNE 
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The  selection  of  contexts  is  strictly  the  systems  designer's 
choice.   The  system  is  best  kept  as  uncomplicated  as  the 
subject  will  permit.   Rules  and  parameters  will  be  grouped 
by  the  RULEGROUP  and  PROPGROUP  properties,  respectively, 
and  selected  by  the  rule  interpreter/monitor  for  use  in  the 
program.   The  designer's  responsibility  is  to  design  a  logical 
set  of  backward -chaining  rules,  to  define  all  rules  and 
parameters,  and  to  structure  the  context  tree. 

B.   ARTIFICIAL  INTELLIGENCE  MOTIVATIONS 

The  following  example  and  the  motivation  descriptions 
for  AI  work  are  offered  to  stimulate  further  developments 
in  the  field. 

Artificial  Intelligence  programs  may  be  described  as 
containing  powerful  search  algorithms  (control  strategies) 
operating  upon  data,  bases  in  order  to  efficiently  produce 
relevant  logical  inferences.   This  description  mentions 
algorithms,  necessary  to  all  computer  work,  and  the  use  of 
data  but  the  energy  required  to  accurately  represent  data  in 
a  "real  world"  manner  must  also  be  emphasized  [Sacerdoti, 
1979].   Thus  the  two  key  issues  in  AI  work  are  control  and 
data  representation. 

Representation  and  control  become  important  when  going 
beyond  toy  systems  and  proceeding  into  more  useful  programs. 
A  chess  game  is  used  as  an  example.   The  game  can  be 
described  as  the  use  of  a  database  consisting  of  a  number 
of  legal  moves.   This  description  may  describe  the  game  but 
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does  not  tell  one  how  to  build  a  better  chess  program  or  how 
to  play  better  chess. 

Therefore,  two  major  motivations  are  established  for 
Artificial  Intelligence  work.   First,  analogous  to  building 
a  better  chess  program,  there  is  the  engineering  motivation 
to  make  computers  more  useful  by  making  them  "smarter"  -- 
endowing  them  with  common  sense,  giving  them  access  to  a 
full  sensory  world,  and  enabling  them  to  understand  humans 
on  the  human's  terms.   Secondly,  analogous  to  playing  better 
chess,  there  is  the  scientific  motivation  to  study  the 
nature  of  knowledge  and  the  mechanisms  of  intelligent 
behavior  independent  of  their  embodiment  in  man  or  machine. 
As  with  any  computing  device  or  concept,  Artificial  Intelli- 
gence work  is  designed  to  extend  man's  capabilities  permitting 
him  to  perform  more  and,  hopefully,  better  accomplishments. 

C.   STUDY  AREAS 

Of  the  time  expended  to  complete  this  thesis,  the  major 
portion  (approximately  three  and  one  half  months)  was  occu- 
pied by  learning  the  EMYCIN  system  and  the  supportive  concepts 
and  programs.   This  included  a  study  of  predicate  calculus 
as  it  applies  to  Artificial  Intelligence,  the  study  of  pro- 
duction rules,  the  use  of  backward -chaining  in  a  goal-seeking 
system,  an  overview  of  the  LISP  programming  language  and  its 
functions,  and  the  use  of  the  ARPANET  system  which  permitted 
the  transfer  of  the  EMYCIN  file  from  Stanford  University 
to  the  University  of  Southern  California.   The  transfer  of 
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the  file,  and  the  resulting,  successful  portability  was 
facilitated  by  both  schools  using  DEC-1090  computers  with 
the  TOPS-20  operating  system.   Additionally,  familiarity 
with  user  features  of  the  TENEX  operating  system,  the  HERMES 
automatic  message  handling  system,  the  Experimental  Editor 
(XED) ,  and  debugging  procedures  used  with  the  INTERLISP 
programming  language  were  also  required  to  complete  this 
thesis.   Continued  work  in  AI ,  in  particular  the  DECAIDS  program 
using  the  ARPANET,  will  require  a  review  of  the  areas  of  study 
listed. 

In  order  to  successfully  complete  an  AI  project,  such  as 
DECAIDS,  additional  time  must  be  scheduled  for  deriving  the 
data  to  be  used  in  a  knowledge  base.   Coincident  to  the 
previous  list  of  study  areas  was  the  effort  required  to  collect 
the  required  expert  knowledge.   The  modeling  of  a  management 
system  required  approximately  one  and  one  half  month's  time. 
The  management  modeling  process  continued  into  what  was 
informally  referred  to  as  the  use  of  the  EMYCIN  "production 
rule  language." 

The  lack  of  user  oriented  documentation  concerning  the 
use  of  the  EMYCIN  production  rule  language  caused  some  delays 
in  completing  the  knowledge  base  and  producing  a  running 
program.   While  an  "EMYCIN. DOC"  documentation  file  has  been 
prepared  by  the  Stanford  AI  group,  it  has  been  written  more 
as  a  set  of  very  complete  notes  for  the  Stanford  group 
rather  than  as  a  set  of  user  oriented  instructions.   Problems 
in  getting  the  DECAIDS  program  on-line  were  resolved  by 
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ARPANET  messages,  telephone  calls,  and  personal  visits  to 
the  Stanford  group  and  by  reference  to  the  INTERLISP 
manual.   This  interaction  between  NPS  and  Stanford  did  assist 
the  efforts  of  the  AI  people  at  Stanford  in  extending  the 
user  information  contained  in  the  documentation  for  EMYCIN. 

Acknowledgement  for  a  vast  amount  of  information  and 
selfless  assistance  in  sharing  her  knowledge  of  production 
rules  and  their  application  to  AI  is  given  to  Miss  Carlisle 
Scott  of  the  Stanford  University  Computer  Science  Department. 
Recognition  is  also  given  to  Dr.  E.  Fiegenbaum  (Chairman  of 
the  Computer  Science  Department  at  Stanford  University)  for 
his  assistance,  and  to  Dr.  Nils  J.  Nilsson  (Stanford  Research 
International,  Menlo  Park,  California)  for  permission  to 
use  material  from  his  forthcoming  book,  Artificial  Intelligence 


A  Framework. 
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APPENDIX  A 
DECAIDS  PRODUCTION  RULES 


RULEOOl 

CThis  rule  is  def i rational ?    applies  to  ORGANIZATION r  and  is  tried 
when  information  is  received  about  THE  DECISIONS 

If:   An  attempt  has  been  marie    to  deduce  THE  DECISION 
Then:   Display  THE  DECISION 


premise:   <$AND  (ONCEKNOWN  CNTXT  DECAIDS  T)) 
action:   (PRINTCONCLUSIONS  CNTXT  DECAIDS  T) 

CORGRULES/antecedentU 


RULE002 

CThis  rule  applies  to  ORGANIZATION)-  and  is  tried  in  order  to  find  out 
about  THE  DECISION! 

If:   1)  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  known, 

2)  THETYPE  OF  OUTPUT  DEVICE  TO  BE  USED  is  known > 

3)  THE  RECOMMENDED  INSTALLATION  TO  BE  USED  is  known r     and 

A)     THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is 
known 
Then:   It  is  definite  (1.0)  that  the  following  is  one  of  THE 

DECISION:  USE  THE  FOLLOWING  TYPE  SYSTEM  <tapsus>  THE 
OUTPUT  SHOULD  BE  DISPLAYED  ON  (output;-  THE  MANNER  OF 
INSTALLATION  SHOULD  BE  <install>  AND  THE  RECOMMENDATION 
FOR  TRAINING  AND  ASSISTANCE  IS  <trsl>  . 


PREMISE.'   <$AND  (KNOWN  CNTXT  TYPSYS) 
(KNOWN  CNTXT  OUTF'UT) 
(KNOWN  CNTXT  INSTALL) 
(KNOWN  CNTXT  TRG ) ) 
ACTION:   (CONCLUDETEXT  CNTXT  DECAIDS  (TEXT  NIL 

"USE  THE  FOLLOWING  TYPE  SYSTEM" 
(VAL.l  CNTXT  TYPSYS) 

•THE  OUTPUT  SHOULD  BE  DISPLAYED  ON' 
(VAL1  CNTXT  OUTPUT) 

•THE  MANNER  OF  INSTALLATION  SHOULD  BE ' 
(VAL1  CNTXT  INSTALL) 

•AND  THE  RECOMMENDATION  FOR  TRAINING  AND  ASSISTANCE  IS' 

(VAL1  CNTXT  TRG) 
■  .  '  ) 
TALLY  1000) 
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RULE003 

CThis  rule  applies  to  ORGANIZATION t    and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED] 

If:   THE  ORGANIZATION'S*  STRUCTURE  is  centralized 

Then!   1)  There  is  strongly  suggestive  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-timer 

2)  There  is  strongly  suggestive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  individual -terminals r 

3)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  pyramidal t    and 

4)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  do- 
not-hire-specialists 

PREMISE:   ($AND  (SAME  CNTXT  INFORMAL  CENTRALIZED)) 

REAL-TIME  TALLY  800) 
INDIVIDUAL-TERMINALS  TALLY 

.  PYRAMIDAL  TALLY  800) 
DO-NOT-HI RE-SPECIALISTS  TALLY 


action: 

(DO-ALL  (CONCLUDE 

CNTXT 

TYPSYS 

(CONCLUDE 

CNTXT 
800) 

OUTPUT 

(CONCLUDE 

CNTXT 

INSTAL 

(CONCLUDE 

CNTXT 
800)  ) 

TRG  DO 

C0RGRULES3 

RULE004 

CThis  rule  applies  to  ORGANIZATION ?    and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USEDr  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED: 

IfJ   THE  LEADER'S  LEVEL  OF  TRAINING  is  skilled 

Then:   1)  There  is  strongly  suggestive  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-time t 

2)  Hi re-speci3lists ? 

3)  There  is  strongly  suggestive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  individual -te rmina 1 s , 

4)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  pyramidal t     and 

5)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  do- 
not-hire-speci3lists 


PREMISE:   (SAND  (SAME  CNTXT  LEADER-TRAINING  SKILLED)) 
ACTION:   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  REAL-TIME  TALLY  800) 
HIRE-SPECIALISTS 
(CONCLUDE  CNTXT  OUTPUT  INDIVIDUAL-TERMINALS  TALLY 

800) 
(CONCLUDE  CNTXT  INSTALL  PYRAMIDAL  TALLY  800) 
(CONCLUDE  CNTXT  TRG  DO-NOT-HIRE-SPECI ALISTS  TALLY 
800)  ) 

CORGRULESD 
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RULE005 

CThis  rule  applies  to  ORGANIZATION r     and  is  tried  in  order  to  find  out 
about  THE  TYF'E  OF    SYSTEM  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USEDr  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED} 


If:   THE  LEADER'S  LEVEL  OF  TRAINING  is  known 

Then:   1)  There  is  suddestive  evidence  (.5)  that  THE  TYPE  OF  SYSTEM 
RECOMMENDED  TO  BE  USED  is  real-timer 

There  is  suggestive  evidence  (.5)  that  THETYPE  OF  OUTPUT 
DEVICE  TO  BE  USED  is  individual-terminals* 
There  is  suggestive  evidence  (.5)  that  THE  RECOMMENDED 
INSTALLATION  TO  BE  USED  is  ur.3V3i  lable  r    and 
There  is  suggestive  evidence  (.6)  that  THE  RECOMMENDED 
TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  hi  re-special ists 


2) 
3) 

4) 


PREMISE:   (SAND  (KNOWN  CNTXT  LEADER-TRAINING  UNSKILLED)) 

ACTION!   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  REAL-TIME  TALLY  500) 

(CONCLUDE  CNTXT  OUTPUT  INDIVIDUAL-TERMINALS  TALLY 

500) 

(CONCLUDE  CNTXT  INSTALL  UNAVAILABLE  TALLY  500) 

(CONCLUDE  CNTXT  TRG  HIRE-SPECIALISTS  TALLY  600)) 

CORGRULESU 


RULE006 

CThis  rule  applies  to  ORGANIZATION ?    and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USEDr  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED.  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED!! 

If!   THE  STAFF'S  LEVEL  OF  TECHNICAL  TRAINING  is  known 
Then:   1)  There  is  suggestive  evidence  (.5)  that  THE  TYPE  OF  SYSTEM 
RECOMMENDED  TO  BE  USED  is  real-timer 

2)  There  is  suggestive  evidence  (.5)  that  THETYPE  OF  OUTPUT 
DEVICE  TO  BE  USED  is  indi vidual-terminals r 

3)  There  is  strongly  suggest ive  evidence  (.8)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  pyramidal t    and 

4)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  do- 
no  t-hire-special ists 


PREMISE.*   (tAND  (KNOWN  CNTXT  STFFTRG  SKILLED)) 


ACTION:   (DO-ALL 


(CONCLUDE 
(CONCLUDE 

(CONCLUDE 
(CONCLUDE 


CNTXT 

CNTXT 

500) 

CNTXT 

CNTXT 

000)  ) 


TYPSYS  REAL-TIME  TALLY  500) 
OUTPUT  INDIVIDUAL-TERMINALS  TALLY 

INSTALL  PYRAMIDAL  TALLY  800) 

TRG  DO-NOT-HIRE-SPECIALISTS  TALLY 


CORGRULESJ 
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RULE007 

CThis  rule  applies  to  ORGANIZATION ?    and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED: 

If?   THE  STAFF'S  LEVEL  OF  TECHNICAL  TRAINING  is  unskilled 
Then!   1)  There  is  strongly  suggestive  evidence  (.3)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-time t 

2)  There  is  strongly  suggestive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  indi vidual-terminals i 

3)  There  is  strongly  suggestive  evidence  (.3)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  divisional,  and 

4)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  hire- 
special  ists 


PREMISE:   (*AND  (SAME  CNTXT  STFFTRG  UNSKILLED)) 


ACTION:   (DO-ALL 


(CONCLUDE 
(CONCLUDE 

(CONCLUDE 
(CONCLUDE 


CNTXT 

CNTXT 

800) 

CNTXT 

CNTXT 


TYPSY3 
OUTPUT 


REAL-TIME 
INDI  VIDUA!. 


TALLY  800) 
-TERMINALS 


TALLY 


INSTALL  DIVISIONAL  TALLY  300) 
TRG  HIRE-SPECIALISTS  TALLY  800)) 


CORGRULESJ 


RULE008 

CThis  rule  applies  to  ORGANIZATION *  and  is  tried  in  order  to  find  out 
3bout  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED.  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED] 

If:   THE  LEVEL  OF  THE  TASK'S  STRESS  is  high 

Then?   1)  There  is  strongly  sudsiest lve  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real -timer 

2)  There  is  strondla  suggestive  evidence  (.3)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  individual-terminals* 

3)  There  is  strongly  suggestive  evidence  (.0)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  pyramidal*  and 

4)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  do- 
no  t-hi  re- special ists 


PREMISE.*   ($AND  (SAME  CNTXT  STRESS  HIGH)) 


ACTION:   (DO-ALL 


(CONCLUDE 
(CONCLUDE 

(CONCLUDE 
(CONCLUDE 


CNTXT 

CNTXT 

800) 

CNTXT 

CNTXT 

800)  ) 


TYPSYS  REAL-TIME  TALLY  800) 
OUTPUT  INDIVIDUAL-TERMINALS  TALLY 

INSTALL  PYRAMIDAL  TALLY  800) 

TRG  DO-NOT-HIRE-SPECIALISTS  TALLY 


CORGRULESD 
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RULE009 

CThis  rule  applies  to  ORGANIZATION ?    and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USEDr  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED} 

If:   THE  LEVEL  OF  THE  'TASK'S  STRESS  is  low 

Then?   1)  There  is  suSdestive  evidence  (.5)  that  THE  TYPE  OF  SYSTEM 
RECOMMENDED  TO  BE  USED  is  real-timer 

2)  There  is  sus33estive  evidence  (.5)  th3t  THETYPE  OF  OUTPUT 
DEVICE  TO  BE  USED  is  individual-terminals* 

3)  There  is  suasestive  evidence  (.5)  that  THE  RECOMMENDED 
INSTALLATION  TO  BE  USED  is  divisional r  and 

4)  There  is  susJdestive  evidence  (.5)  that  THE  RECOMMENDED 
TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  do-not-h i re- 
specialists 


PREMISE:   ($AND  (SAME  CNTXT  STRESS  LOU)) 

ACTION:   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  REAL-TIME  TALLY  500) 


(CONCLUDE 

(CONCLUDE 
(CONCLUDE 


CNTXT 
500) 
CNTXT 
CNTXT 
500)  ) 


OUTPUT  INDIVIDUAL-TERMINALS  TALLY 

INSTALL  DIVISIONAL  TALLY  500) 

TRG  DO-NOT-HIRE-SPECIALISTS  TALLY 


CORGRULESU 


RULE013 


CThis  rule  applies  to  ORGANIZATION  r  3nd  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USEDr  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USEDr  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED} 

If:   THE  TASK  DEFINITION  is  clearly-defined 

Then:   1)  There  is  strongly  sussaestive  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-timer 

2)  There  is  stronsly  su^destive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  individual-terminals- 

3)  There  is  stronsly  suaaestive  evidence  (.8)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  pyramidal r  and 

4)  There  is  strondly  susldestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  do- 
no  t-hire-specialists 


PREMISE?   ($AND  (SAME  CNTXT  PROBDEF  CLEARLY-DEFINED)) 


ACTION:   (DO-ALL 


(CONCLUDE 
(CONCLUDE 

(CONCLUDE 
(CONCLUDE 


CNTXT 

CNTXT 

800) 

CNTXT 

CNTXT 

800)  ) 


TYPSYS  REAL-TIME  TALLY  800) 
OUTPUT  INDIVIDUAL-TERMINALS 


TALLY 


INSTALL  PYRAMIDAL  TALLY  800) 

TRG  DO-NOT-HIRE-SPECIALISTS  TALLY 


CORGRULESJ 
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RULE014 

CThis  rule  applies  to  ORGANIZATION /  and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USEDr  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED^ 

If:   THE  TASK  DEFINITION  is  ambiguous 

Then:   1)  There  is  suasestive  evidence  (.5)  that  THE  TYPE  OF  SYSTEM 
RECOMMENDED  TO  BE  USED  is  real-timer 

2)  There  is  suaaestive  evidence  (.5)  th3t  THETYPE  OF  OUTPUT 
DEVICE  TO  BE  USED  is  individual-terminals / 

3)  There  is  susi^estive  evidence  (.5)  that  THE  RECOMMENDED 
INSTALLATION  TO  BE  USED  is  divisional/  and 

4)  There  is  suaaestive  evidence  (.5)  that  THE  RECOMMENDED 
TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  do-not-hire- 
speci3lists 


PREMISE.*   ($AND  (SAME  CNTXT  PROBDEF  AMBIGUOUS)) 

ACTION:   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  REAL-TIME  TALLY  500) 


(CONCLUDE 

(CONCLUDE 
(CONCLUDE 


CNTXT 
500) 
CNTXT 
CNTXT 
500)  ) 


OUTPUT  INDIVIDUAL-TERMINALS  TALLY 

INSTALL  DIVISIONAL  TALLY  500) 

TRG  DO-NOT-HIRE-SPECIALISTS  TALLY 


C0RGRULES3 


RULE015 


CThis  rule  applies  to  ORGANIZATION/  and  is  tried  in  order  to  find  out 
3bout  THE  TYPE  OF  SYSTEM  RECOMnENDED  TO  BE  USED/  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USEDr  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED} 

If:   THE  ORGANIZATION'S  STRUCTURE  is  centralized 

Then:   1)  There  is  strondly  suslflestive  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-time/ 

2)  There  is  stronsJly  sua^estive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  indi vidua  1 -terminal s r 

3)  There  is  strongly  sud3estive  evidence  (.8)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  pyramidal/  and 

4)  There  is  stronaly  sua^estive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  do- 
not-hire-specialists 


PREMISE:   (SAND  (SAME  CNTXT  INFORMAL  CENTRALIZED)) 


ACTION:   (DO-ALL 


(CONCLUDE 
(CONCLUDE 

(CONCLUDE 
(CONCLUDE 


CNTXT 

CNTXT 

800) 

CNTXT 

CNTXT 

800)  ) 


TYPSYS  REAL-TIME  TALLY  800) 
OUTPUT  INDIVIDUAL-TERMINALS 


TALLY 


INSTALL  PYRAMIDAL  TALLY  800) 

TRG  DO-NOT-HIRE-SPECIALISTS  TALLY 


CORGRULESU 
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RULE018 

CThis  rule  applies  to  ORGANIZATION  *  arid    is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USEDr  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  1 

If:   THE  ORGANIZATION'-S  STRUCTURE  is  consultative 


Then:   1)  There  is  strongly  suggestive  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-timer 

2)  There  is  strongly  suSdestive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO    BE  USED  is  individual-terminals* 

3)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  divisional*  and 

4)  There  is  suggestive  evidence  (.5)  that  THE  RECOMMENDED 
TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  do-not-hire- 
special i  sts 


PREMISE:   ($AND  (SAME  CNTXT  INFORMAL  CONSULTATIVE)) 

ACTION:   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  REAL-TIME  TALLY  BOO ^ 

(CONCLUDE  CNTXT  OUTPUT  INDIVIDUAL-TERMINALS  TALLY 

800) 
(CONCLUDE  CNTXT  INSTALL  DIVISIONAL  TALLY  300) 
(CONCLUDE  CNTXT  TRG  DO-NOT-HIRE-SPECIALISTS  TALLY 
500)  ) 

CORGRULESD 


RULE019 


CThis  rule  applies  to  ORGANIZATION*  and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 


If!   THE  ORGANIZATION'S  STRUCTURE  is  partially-delegated 
Then:   1)  There  is  strongly  suggestive  evidence  (.3)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-time* 

2)  There  is  strongly  suggestive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  individual-terminals* 

3)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  divisional*  and 

4)  There  is  suggestive  evidence  (.5)  that  THE  RECOMMENDED 
TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  hi  re-SPeci al  i.st< 


PREMISE:   ($AND  (SAME  CNTXT  INFORMAL  PARTIALLY-DELEGATED)) 
ACTION:   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  REAL-TIME  TALLY  800) 

(CONCLUDE  CNTXT  OUTPUT  INDIVIDUAL-TERMINALS  TALLY 

800) 
(CONCLUDE  CNTXT  INSTALL  DIVISIONAL  TALLY  800) 
(CONCLUDE  CNTXT  TRG  HIRE-SPECIALISTS  TALLY  500)) 


C0RGRULE51 
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RULE016 

CThis  rule  applies  to  ORGANIZATION*  and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED?  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED] 

If!   THE  ORGANIZATION'S  STRUCTURE  is  line 

Then:   1)  There  is  susSsiestive  evidence  (.5)  that  THE  TYPE  OF  SYSTEM 
RECOMMENDED  TO  BE  USED  is  real-time? 

2)  There  is  suggestive  evidence  (.5)  that  THETYPE  OF  OUTPUT 
DEVICE  TO  BE  USED  is  individual  --terminal  s  ? 

3)  There  is  suggestive  evidence  (.5)  that  THE  RECOMMENDED 
INSTALLATION  TO  BE  USED  is  pyramidal ?  and 

4)  There  is  suggestive  evidence  (.5)  that  THE  RECOMMENDED 
TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  hi re-speci al i sts 


PREMISE:   ($AND  (SAME  CNTXT  FORMAL  LINE)) 


action: 

(DO-ALL  (CONCLUDE 

CNTXT 

TYPSYS 

(CONCLUDE 

CNTXT 
500) 

OUTPUT 

(CONCLUDE 

CNTXT 

INSTAL 

(CONCLUDE 

CNTXT 

TRG  HI 

CORGRULES: 

RULE017 

REAL-TIME  TALLY  500) 
I ND I VI DUAL -TERMINALS 


TALLY 


PYRAMIDAL  TALLY  500) 
HIRE-SPECIALISTS  TALLY  500)) 


CThis  rule  applies  to  ORGANIZATION?  and  is  tried  in  order  to  find 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED?  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED?  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED! 


out 


IfJ   THE  ORGANIZATION'S  STRUCTURE  is  THE  FORMAL  COMPOSITION  OF  THE 

ORGANIZATION'S  STRUCTURE 
Then:   1)  There  is  strongly  surest lve  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-time? 

2)  There  is  strongly  suggestive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE    USED  is  individual -terminal s ? 

3)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  pyramidal?  and 

4)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  do- 
not  -hire- special is  Is 


PREMISE:   ($AND  (SAME  CNTXT  FORMAL  STAFF)) 


ACTION:   (DO-ALL 


(CONCLUDE 
(CONCLUDE 

(CONCLUDE 
(CONCLUDE 


CNTXT 

CNTXT 

800) 

CNTXT 

CNTXT 

000)  ) 


TYPSYS  REAL-TIME  TALLY  800) 
OUTPUT  INDIVIDUAL-TERMINALS 


TALLY 


INSTALL  PYRAMIDAL  TALLY  800) 

TRG  DO-NOT-HIRE-SPECIALISTS  TALLY 


CORGRULESJ 
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RULE022 

CThis  rule  applies  to  ORGANIZATION r  and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED] 


Ift   THE  ORGANIZATION'S  STRUCTURE  is  decentralized 

Then:   1)  There  is  strongly  suggestive  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-timer 
There  is  strongly  suggestive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  individual-terminals* 
There  is  strongly  susiSestive  evidence  (.8)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  divisional-  and 
There  is  strongly  sugaestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  hire- 
special  ists 


2) 
3) 
4) 


PREMISE!   (*AND  (SAME  CNTXT  INFORMAL  DECENTRALIZED)) 


action: 

(DO-ALL  (CONCLUDE 

CNTXT 

TYPSYS 

(CONCLUDE 

CNTXT 
800) 

OUTPUT 

(CONCLUDE 

CNTXT 

INSTAL 

(CONCLUDE 

CNTXT 

TRG  HI 

C0RGRULES3 

RULE023 

REAL-TIME  TALLY  300) 
INDIVIDUAL-TERMINALS 


TALLY 


DIVISIONAL  TALLY  800) 
HIRE-SPECIALISTS  TALLY  300)) 


CThis  rule  applies  to  ORGANIZATION  and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED: 


If:   THE  LEADER'S  STYLE  OF  OPERATION  is  task-oriented 
ThenJ   1)  There  is  strongly  suggestive  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-timer 
There  is  stronsly  suggestive  evidence  (.3)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  individual-terminals* 
There  is  strongly  suggestive  evidence  (.3)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  pyramidal*  and 
There  is  suggestive  evidence  (.5)  that  THE  RECOMMENDED 
TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  unavailable 


2) 
3) 
4) 


premise:   ($AND  (SAME  CNTXT  STYLE  TASK-ORIENTED )) 


ACTION:   (DO-ALL 


(CONCLUDE 
(CONCLUDE 

(CONCLUDE 
(CONCLUDE 


CNTXT 

CNTXT 

800) 

CNTXT 

CNTXT 


TYPSYS  REAL-TIME  TALLY  300) 
OUTPUT  INDIVIDUAL-TERMINALS 


TALLY 


INSTALL  PYRAMIDAL  TALLY  800) 
TRG  UNAVAILABLE  TALLY  500)) 


CORGRULESU 
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RULE024 

CThis  rule  applies  to  ORGANIZATION  *    and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USEDf  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED} 

If:   THE  INDIVIDUAL'S  TECHNICAL  TRAINING  IN  DECISION  ANALYSIS  is 

hi  ah 
Then?   1)  There  is  strongly  sus^estive  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-time ? 

2)  There  is  strongly  surest ive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  individual-terminals , 

3)  There  is  strondly  susaestive  evidence  (.8)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  pyramidal ,    and 

4)  There  is  stronaly  susiSestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is 
train-exist  ins:- staff 


PREMISE:   ($AND  (SAME  CNTXT  TRAINING  HIGH)) 

ACTION:   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  REAL-TIME  TALLY  800) 

(CONCLUDE  CNTXT  OUTPUT  INDIVIDUAL-TERMINALS  TALLY 

800) 

(CONCLUDE  CNTXT  INSTALL  PYRAMIDAL  TALLY  800) 

(CONCLUDE  CNTXT  TRG  TRAIN-EXISTING-STAFF  TALLY  800)) 

CQRGRULESU 


RULE025 


CThis  rule  applies  to  ORGANIZATION »  and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED?  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED: 

If:   THE  INDIVIDUAL'S  TECHNICAL  TRAINING  IN  DECISION  ANALYSIS  is 

low 
Then:   1)  There  is  strongly  su^flestive  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  non-real-t  line  r 

2)  There  is  stronsly  susaestive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  la rsSe-screen-displ ays  ? 

3)  There  is  strongly  suasestive  evidence  (.8)  th3t  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  divisional t    and 

4)  There  is  stronaly  suasestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  hire- 
specialists 


PREMISE:   (UAND  (SAME  CNTXT  TRAINING  LOU)) 

ACTION:   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  NON-REAL-TIME  TALLY  800) 

(CONCLUDE  CNTXT  OUTPUT  LARGE-SCREEN-DISPLAYS  TALLY 

000) 

(CONCLUDE  CNTXT  INSTALL  DIVISIONAL  TALLY  800) 

(CONCLUDE  CNTXT  TRG  HIRE-SPECIALISTS  TALLY  800)) 

CORGRULES: 
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RULE026 

CThis  rule  applies    to  ORGANIZATION  r    and  is  tried  in  order  to  firid  out 
about  THE  TYFE  OF  SYSTEN  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED,  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIREDD 

If:   THE  TECHNOLOGICAL  METHODS  AVAILABLE  is  analytical-aids 


Then:   1)  There  is  strongly  su^Sestive  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-timer 

2)  There  is  strongly  suaaestive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  individual-terminals r 

3)  There  is  su23estive  evidence  (.5)  that  THE  RECOMMENDED 
INSTALLATION  TO  BE  USED  is  pyramidal r  and 

4)  There  is  strongly  sudSestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is 
unavai lable 


PREMISE:   <$AND  (SAME  CNTXT  METHODS  ANALYTICAL-AIDS)) 
ACTION?   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  REAL-TIME  TALLY  300) 

(CONCLUDE  CNTXT  OUTPUT  INDIVIDUAL-TERMINALS  TALLY 

800) 
(CONCLUDE  CNTXT  INSTALL  PrRAMIDAL  TALLY  500) 
(CONCLUDE  CNTXT  TRG  UNAVAILABLE  TALLY  800)) 

LQRGRULES1 


RULE027 


CThis  rule  applies  to  ORGANIZATION r  and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USEDr  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USEDr  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED!! 

If:   THE  TECHNOLOGICAL  METHODS  AVAILABLE  is  inventory-aids 
Then:   1)  There  is  sudaestive  evidence  (.5)  that  THE  TYPE  OF  SYSTEM 
RECOMMENDED  TO  BE  USED  is  real-timer 

2)  There  is  sussestive  evidence  (.5)  that  THETYPE  OF  OUTPUT 
DEVICE  TO  BE  USED  is  individual-terminals r 

3)  There  is  suSdestive  evidence  (.5)  that  THE  RECOMMENDED 
INSTALLATION  TO  BE  USED  is  pyramidal r  and 

4)  There  is  suaaestive  evidence  (.5)  that  THE  RECOMMENDED 
TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  unavailable 


PREMISE:   (SAND  (SAME  CNTXT  METHODS  INVENTORY-AIDS)) 

ACTION:   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  REAL-TIME  TALLY  500) 

(CONCLUDE  CNTXT  OUTPUT  INDIVIDUAL-TERMINALS  TALLY 

500) 
(CONCLUDE  CNTXT  INSTALL  PYRAMIDAL  TALLY  500) 
(CONCLUDE  CNTXT  TRG  UNAVAILABLE  TALLY  500)) 


C0RGRULES3 
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RULE028 

CThis  rule  applies  to  ORGANIZATION *  and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED,  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED,  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED] 

If  J   The  technological  knowledae-level  is  skilled 

ThenJ   1)  There  is  su^estive  evidence  (.5)  that  THE  TYPE  OF  SYSTEM 
RECOMMENDED  TO  BE  USED  is  unavailable* 

2)  There  is  suaaestive  evidence  (.5)  that  THETYPE  OF  OUTPUT 
DEVICE  TO  BE  USED  is  unavailable? 

3)  There  is  su33estive  evidence  (.5)"  that  THE  RECOMMENDED 
INSTALLATION  TO  BE  USED  is  unavailable*  and 

4)  There  is  strongly  susis'estive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  do» 
not-hire-specialists 


PREMISE.'   (SAND  (SAME  CNTXT  KNOWLEDGE-LEVEL  SKILLED)) 
ACTION:   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  UNAVAILABLE  TALLY  500) 
(CONCLUDE  CNTXT  OUTPUT  UNAVAILABLE  TALLY  500) 
(CONCLUDE  CNTXT  INSTALL  UNAVAILABLE  TALLY  500) 
(CONCLUDE  CNTXT  TRG  DO-NOT-HIRE-SPECIALISTS  TALLY 
800)) 


CORGRULESD 


RULE029 


CThis  rule  applies  to  ORGANIZATION*  and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED!] 

IfJ   The  technological  knowledSe-level  is  unskilled 

Then.'   1)  There  is  strongly  5u33estive  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  unavailable* 

2)  There  is  strongly  surest  lve  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  unavailable* 

3)  There  is  stronaly  susisiestive  evidence  (.8)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  unavailable*  and 

A)    There  is  strongly  susS.^estive  evidence  (.8)  that  THE 

RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is  hire- 
special  ists 


PREMISE:   (SAND  (SAME  CNTXT  KNOWLEDGE-LEVEL  UNSKILLED)) 
ACTION:   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  UNAVAILABLE  TALLY  800) 
(CONCLUDE  CNTXT  OUTPUT  UNAVAILABLE  TALLY  800) 
(CONCLUDE  CNTXT  INSTALL  UNAVAILABLE  TALLY  800) 
(CONCLUDE  CNTXT  TRG  HIRE-SPECIALISTS  TALLY  800)) 


CORGRULESH 
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RULE030 

[This  rule  applies  to  ORGANIZATION t    and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED*  THETYFE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIREDJ 


If:   THE  ORGANIZATION'S  STRUCTURE  is  line 

Then!   1)  There  is  strongly  suggestive  evidence  (.8)  that 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-time* 

2)  There  is  strongly  suggestive  evidence  (.8)  th3t 
OF  OUTPUT  DEVICE  TO  BE  USED  is  unavailable* 

3)  There  is  strongly  suggestive  evidence  (.8)  that 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  pyramidal* 

4)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  L 
unav3i lable 


THE  TYPE 

THETYPE 

THE 

*  a  n  d 

PREMISE:   (*AND  (SAME  CNTXT  FORMAL  LINE)) 


ACTION:   (DO-ALL 


(CONCLUDE  CNTXT  TYPSYS  REAL-TIME  TALLY  800) 

(CONCLUDE  CNTXT  OUTPUT  UNAVAILABLE  TALLY  800) 

(CONCLUDE  CNTXT  INSTALL  PYRAMIDAL  TALLY  800) 

(CONCLUDE  CNTXT  TRG  UNAVAILABLE  TALLY  800)) 


CORGRULES: 


RULE031 


CThis  rule  3PPlies  to  ORGANIZATION*  and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED: 


If: 

Then; 


THE  ORGANi; 
1 )  There 


ATION'S  STRUCTURE  is  functional 
is  strongly  sugaestive  evidence 


( .8)  that  THE  TYPE 


OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  non-real-time* 

2)  There  is  strongly  suggestive  evidence  (»3)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  unavailable* 

3)  There  is  strongly  suggestive  evidence  (.3)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  divisional*  and 

4)  There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is 
unavai lable 


PREMISE:   (SAND  (SAME  CNTXT  FORMAL  FUNCTIONAL)) 


ACTION:   (DO-ALL 


(CONCLUDE  CNTXT  TYPSYS  NON-REAL-TIME  TALLY  800) 

(CONCLUDE  CNTXT  OUTPUT  UNAVAILABLE  TALLY  800) 

(CONCLUDE  CNTXT  INSTALL  DIVISIONAL  TALLY  800) 

(CONCLUDE  CNTXT  TRG  UNAVAILABLE  TALLY  800)) 


CORGRULES: 
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RULE032 

CThis  rule  applies  to  ORGANIZATION*  and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USED*  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USED*  THE  RECOMMENDED  INSTALLATION  TO  BE 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED] 


IfJ   THE  ORGANIZATION'S  STRUCTURE  is  matrix 

Then.'   1)  There  is  strongly  suggestive  evidence  (.8)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  nor,-  real  -time  r 
There  is  strongly  suggestive  evidence  (.8)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  unavai lable * 
There  is  strongly  surest lve  evidence  (.8)  that  THE 
RECOMMENDED  INSTALLATION  TO  BE  USED  is  divisional r  and 
There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is 
unavai lable 


2) 

3) 
4) 


PREMISE:   ($AND  (SAME  CNTXT  FORMAL  MATRIX)) 


ACTION:   (DO-ALL 


(CONCLUDE  CNTXT  TYP3YS  NON-REAL-TIME  TALLY  800) 

(CONCLUDE  CNTXT  OUTPUT  UNAVAILABLE  TALLY  800) 

(CONCLUDE  CNTXT  INSTALL  DIVISIONAL  TALLY  800) 

(CONCLUDE  CNTXT  TRG  UNAVAILABLE  TALLY  800)) 


iORGRULESJ 


RULE033 


CThis  rule  applies  to  ORGANIZATION  r  and  is  tried  in  order  to  find  out 
about  the  recommended  informal  structure] 

If:   THE  ORGANIZATION'S  STRUCTURE  is  notavai lable 
Then:   There  is  strongly  suggestive  evidence  (.8)  that  the 
recommended  informal  structure  is  centralized 


PREMISE:   <$AND  (SAME  CNTXT  INFORMAL  NOTAVATLABLE)  ) 
ACTION:   (CONCLUDE  CNTXT  UNKSTRUC  CENTRALIZED  TALLY  800) 

CORGRULES: 


RULE034 

CThis  rule  applies  to  ORGANIZATION*  and  is  tried  in  order  to  find  out 
about  the  recommended  informal  structure!! 

If:   The  recommended  informal  structure  is  known 

Then!   It  is  definite  (1.0)  that  the  following  is  the  recommended 

informal  structure:  THE 

RECOMMENDED  INFORMAL  STRUCTURE  TO  USE  IS  <unkst ruc> 


PREMISE:   ($AND  (KNOWN  CNTXT  UNKSTRUC)) 
ACTION:   (CONCLUDETEXF  CNTXT  UNKSTRUC  (TEXT  NIL 

•  THE 
RECOMMENDED  INFORMAL  STRUCTURE  TO  USE  IS* 

(VAL1  CNTXT  UNKSTRUC)) 
TALLY  1000) 


101 


RULE035 

CThis  rule  is  definitional?  applies  to  ORGANIZATION?  and  is  tried 
when  information  is  received  about  the  recommended  informal 
structured 

If  J   An  attempt  has  been  made  to  deduce  the  recommended  informal 

structure 
Then!   Display  the  recommended  informal  structure 


PREMISE!   (SAND  (ONCEKNOUN  CNTXT  UNKSTRUC  t)) 
ACTION:   (PRINTCONCLUSIONS  CNTXT  UNKSTRUC) 

CORGRULES/anteeedentH 


RULE036 

CThis  rule  applies  to  ORGANIZATION r     and  is  tried  in  order  to  find  out 
about  THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  USEDr  THETYPE  OF 
OUTPUT  DEVICE  TO  BE  USEDr  THE  RECOMMENDED  INSTALLATION  TO  Lr[ 
USED  or  THE  RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED!] 


if: 

THE 

Then 

I       1) 

2) 

3) 

4) 


IMPLEMENTATION/CONSTRUCTION  STATUS  OF  THE  SYSTEM 
There  is  strongly  suggestive  evidence  (.3)  that  THE  TYPE 
OF  SYSTEM  RECOMMENDED  TO  BE  USED  is  real-time? 
There  is  strongly  suggestive  evidence  (.3)  that  THETYPE 
OF  OUTPUT  DEVICE  TO  BE  USED  is  individual-terminals  * 
There  is  strongly  suggestive  evidence  (.8)  that  THE 

RECOMMENDED  INSTALLATION  TO  BE  USED  is  pyramidal >  and 
There  is  strongly  suggestive  evidence  (.8)  that  THE 
RECOMMENDED  TRAINING  OR  ASSISTANCE  TO  BE  ACQUIRED  is 
train -existing-staff 


PREMISE:   ($AND  (SAME  CNTXT  SYSSTAT  YES)) 

ACTION:   (DO-ALL  (CONCLUDE  CNTXT  TYPSYS  REAL-TIME  TALLY  800) 

(CONCLUDE  CNTXT  OUTPUT  INDIVIDUAL-TERMINALS  TALLY 

800) 

(CONCLUDE  CNTXT  INSTALL  PYRAMIDAL  TALLY  800) 

(CONCLUDE  CNTXT  TRG  train-existing-staf f  TALL1    800)) 

C0RGRULES3 


RULE03? 


CThis  rule  applies  to  ORGANIZATION?  and  is  tried 
about  THE  RECOMMENDED  FORMAL  STRUCTURE! 


in  order  to  find  out 


If:   THE  ORGANIZATION'S  STRUCTURE  is  notavai lable 
Then:   There  is  strongly  suggestive  evidence  (.3)  that  THE 
RECOMMENDED  FORMAL  STRUCTURE  is  line 


PREMISE:   ($AND  (SAME  CNTXT  FORMAL  NOTAVAILABLE)) 
ACTION:   (CONCLUDE  CNTXT  FORSTRUC  LINE  TALLY  800) 
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CORGRULESH 


RULE040 


CThis  rule  applies  to  ORGANIZATION »' and  is  tried  in  order  to  find  out 
about  THE  RECOMMENDED  FORMAL  STRUCTURED 

If:   THE  RECOMMENDED  FORMAL  STRUCTURE  is  known 

Thent   It  is  definite  (1.0)  that  the  following  is  THE  RECOMMENDED 

FORMAL  STRUCTURE:  THE  RECOMMENDED  FORMAL  STRUCTURE  1*0  USE 

IS  <forstruc> 


premise:   (SAND  ^ KNOWN  CNTXT  FORSTRUO) 

action:   (CONCLUDETEXT  CNTXT  FORSTRUO  (TEXT  NIL 

•THE  RECOMMENDED  FORMAL  STRUCTURE  TO  USE  IS* 

(VAL1  CNTXT  FORSTRUO) 
TALLY  1000) 

C0RGRULES3 


RULE041 

CThis  rule  is  definitional*  applies  to  ORGANIZATION*  and  is  tried 
when  information  is  received  about  THE  RECOMMENDED  FORMAL 
STRUCTURED 

If:   An  attempt  has  been  made  to  deduce  THE  RECOMMENDED  FORMAL 

STRUCTURE 
Then:   Display  THE  RECOMMENDED  FORMAL  STRUCTURE 


premise:   (SAND  (ONCEKNOWN  CNTXT  FORSTRUC  t)) 
ACTION:   (PRINTCONCLUSIONS  CNTXT  FORSTRUC) 

CORGRULES/antecedentJ 

NIL 
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DEC A  IDS   ORG 
ENVIRONMENT   ORG 
FORMAL   ORG 
FORSTRUC   ORG 

INFORMAL   ORG 
INSTALL   ORG 
KNOWLEDGE-LEVEL 
LEADER-TRAINING 


APPENDIX  B 
DECAIDS  PARAMETER  LISTING 

METHODS   ORG 
ORGANIZATION   VAL 
ORGRULES   ALLNAMES 

OUTPUT   ORG 

PROBDEF   ORG 

PROBTYPE   ORG 
ORG     STAFF   ORG 
ORG     STFFTRG   ORG 

PROP-ORG 


DECAIDS 

antecedent-in:  (ruleood 
updateb-by-the-way:  < ruleood 
updated-by :  ( rule002 > 
trans:  (the  decision) 
legal vals:  text 
multivalued:  t 


STRESS   ORG 
STYLE   ORG 
SYSSTAT   ORG 
TRAINING   ORG 
TRG   ORG 
TYPSYS   ORG 
UNKSTRUC   ORG 


ENVIRONMENT 


TRANS:   (*'s  ENVIRONMENT) 

PROMPT:   (WILL  YOU  COMMENT  ON  THE  LEADER-TRAINING  OR  THE 

STAFF-TRAINING  OF  THE  ENVIRONMENT  OF  THE  ORGAN 
EXPECT:   (LEADER-TRAINING  STAFF-TRAINING) 

labdata:  T 


Z AT I ON?) 


FORMAL 


used-by: 

trans: 
prompt: 


expect: 

labdata: 

reprompt 


(Rules  3?  32  31  30  17 
(THE  ORGANIZATION'S  STR 
(THE  FORMAL  STRUCTURE 
EITHER  LINEf  STAF 
NOTAVAILABLE.  IF 
NEEDED r  TYPE  A  OU 
ORGANIZATION'S  FO 
STAFF  FUNCTIONAL 


16) 
UCTURE) 

OF  THE  ORGANIZATION  CAN  BE 
Ft    MATRIX-  FUNCTIONAL*  OR 
FURTHER  EXPLANATION  OF  THES 


DEF 


TE 


J ED  AS 
.'MS  IS 


(LINE 

T 
(LINE 


EST  ION  MARK.  WHAT  IS 
RMAL  STRUCTURE?) 
MATRIX  NOTAVAILABLE) 


THE 


-  EMPHASIZES  DIRECT  CHAINS  OF  AUTHORITY  AND  UNITY  OF 

COMMAND  STAFF 

ADVISORY  STAFF 

PERSONNEL  FUNC" 

FUNCTIONAL  ACT' 

COMMUNICATIONS t    ETC.  MATRIX  ■■  DRAWS  PERSONNEL  FROM 

ACROSS  DEPARTMf 


-  INCLUDES  AN  INFORMATIONAL  AND 
TO  ASSIST  AND  GUIDE  OPERATTONAI 
T TONAL  -  ARRANGES  PERSONNEL  BY 
TVITY  SUCH  AS  LOGISTICS  * 

FTC.  MATRIX  -  DRAWS  PERSONNEL 
1ENTAL  LINES) 


FORSTRUC 

UPDATED-DY:   (Rules  39  SREFMARK 

used-by :  (rule040) 
containfd-in:  (r;jleo40) 
antecedent -in:  (rule041) 
updated-dy-the-way:  (ruleo43 ) 
trans.'   (the  recommended  formal 
expect:  (line  staff  functional 


40) 


STRUCTURE) 
MATRIX) 
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INFORMAL 

USEB-BY:   (Rules  33  22  21  19  13  15  3) 

TRANS.*   (THE  ORGANIZATION'S  STRUCTURE) 

PROMPT:   (THE  INFORMAL  STRUCTURE  OF  THE  ORGANIZATION  REFERS  TO  THE 
MANNER  IN  WHICH  COMMUNICATION  IS  ACCOMPLISHED.  -3  I'HE 
INFORMAL  STRUCTURE  PEST  DESCRIBED  AS  CENTRALIZED* 
CONSULTATIVE  ■>    TRANSACTIONAL'  PARTIALLY-DELEGATED? 
DECENTRALIZED*  OR  NOTAVA  J'LABLE  ?  IF  FURTHER  EXPLANATION 
IS  NEEDED  f     TYRE  A  QUESTION  MARK',) 

EXPECT:   (CENTRALIZED  CONSULTATIVE  TRANSACTIONAL  PARTIALLY- 
DELEGATED  DECENTRALIZED  NQTAVAILABLE) 

labdata:  T 

REPROMPT:   (CENTRALIZED  -  USES  A  FOCUSED  FLOW  OF  AUTHORITY  in  A 
SINGLE  SOURCE  AT  THE  TOP  OF  THE  HIERARCHY 
CONSULTATIVE  -  MAXIMIZES  PATTERNS  OF  CENTRAL  CONTROL 
BUT  ENCOURAGES  VERTICAL.  AND  UPWARD  COMMUNICATION  OF 
ADVICE  AND  GUIDANCE  FROM  A  PROFESSIONAL  STAFF 
TRANSACTIONAL  -  SIRESSES  OPEN  COMMUNICATION » 
DELIBERATION.  AND  NEGOTIATION*  BOTH  LATERALLY  WITHIN 
LEVELS  AND  VERTICAL. L  Y  A M 0 N G  L E V E L S .   A U T H 0 R I  !  V  M  1  f 
STILL  REMAIN  AT/ WITH  FOR  MANAGEMENT  PARTIALLY  •■ 
DELEGATED  -  DISTRIBUTES  AUTHORITY  AMONG  PROFES:  "ONAL 
STAFF  WHILE  INCREASING  I"HE  NEED  FOR  CO-ORBINC  ICON  OF 
EFFORT.   THE  STAFF  MAY  POSSESS  AUTHORITY  TO  DEVELOP 
ACTION  ALTERNATIVES  BUT  IOP  MANAGEMENT  STILL  RETAINS 
THE  RIGHT  TO  REJECT  AND  MODIFY  DECENTRALIZED 
DELEGATES  AND  DISPERSES  FULL  DECISION-MAKING  POWER 
TO  STAFF  AT  LOWER  LEVELS  OF  THE  HIERARCHY) 

INSTALL 


USEB-BY :   (RULE002) 

CONTAINED- IN J   (RULE002> 

UPDATED-BY:   (Rules  36  32  31  30  2?  28  27  26  25  24  23  22  21  20  1?  13 
17  16  15  14  13  9  S  7  6  5  4  3) 

TRANS:   (THE  RECOMMENDED  INSTALLATION  TO  BE  USED) 

EXPECT:   (PYRAMIDAL  DIVISIONAL  UNAVAILABLE) 

REPROMPT:   (A  divisional  installation  places  authority  in  each 
division  for  independent  systems  while  pyramidal 
installations  place  authorityst  the  top  of  one 
super-system  above  all  divisions*) 

KNOWLEDGE-LEVEL 


USEB-BY :   (Rules  29  23) 

TRANS:   (the  technological  knowledge-level) 

prompt:  (in  regards  to  the  technological  training  required  to 

accomplish  the  task*  is  the  level  of  technical  training 
considered  to  be  skilled-  unskilled r   or  unknown?) 

expect:  (skilled  unskilled) 

labdata:  t 

leader-training 


USEB-BY :   (Rules  5  4) 

TRANS:   (THE  LEADER'S  LEVEL  OF  TRAINING) 

PROMPT:   (Is  the  task  leader's  technical  training  considered  bo  be 

skilled?  unskilled*  or  unknown?) 

expect:  (skilled  unskilled) 
labdata:  t 
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METHODS 

USED- by: 

trans: 

prompt: 

expect: 

labdata: 

reprompt 


OUTPUT 


(Rules  27  26) 
(THE  TECHNOLOGICAL  METHODS  AVAILABLE) 
(ARE  THE  TECHNOLOGICAL  METHODS  USED  ANALYTICAL-AIDS? 

INVENTORY-AIDS.  OR  UNKNOWN?) 
(ANALYTICAL -AIDS  INVENTORY -AIDS ) 
T 
J   (Inventory  3ids  refer  to  administrative  uses  and 

analytical  aids  are  those  which  concern  scientific 
ap-pl  ications .  > 


USED-BY:   (RULE002) 
CONTAINED- IN?   (RULE002) 

UPDATED-BY*.   (Rules  36  32  31  30    0<?  23  27  26  25  24    23  22  21 
17  16  15  1 A    1 3  9  S  7  6  5  4  3 ) 
(the  type  of  output  device  bo  be  used) 
(INDIVIDUAL-TERMIN  A  L  S  L  A  R  G  E  -  S  0  R  E  IT  N  -  D I S  P  L  A ' 


TRANJ 


expect: 

PROBDEF 

USED-BY 

trans: 
prompt: 

expect: 
labdata:  t 

probtype 


UNA  VAIL' 


trans: 
prompt 


expect: 

LABDATA 


(Rules  14  13) 
(THE  TASK  DEFINITION) 
(CONCERNING  THE  PROBLEM  FACING  THE  ORG AN I : 
PROBLEM  CLEARLY-DEFINED y    AMBIGUOUS r    01 
(CLEARLY-DEFINED  AMBIGUOUS ) 


TIONf  i:s 
UNKNOWN? 


(THE  TYPE  OF  PROBLEM  TO  BE  SOL 


(THIS 


PROGRAM  IS  DESIGNED  TO 
U I T  H  A  D  V  [  C  E  C  0  N  C  E  R  N I N  G 
RESOURCES.  IN  ORDER  TO 
USER  WILL  BE  ASKED  TO  F 
ORGANIZATION t  ITS  LEVEL 
ORGANIZATION'S  LEADER r 
DECISION*  AND  THE  TASK- 
IS  THE  TYPE  OF  PROBLEM 


VED) 

PROVIDE  MANAGERS  AT  ALL 

.EVEL' 

THE  USE  OF  THEIR  COMPUT' 

PRO"  IDE  THIS  IN  FOR  MAT  I'M 

n-!E 

ORNISH  DATA  CONCERNING ' 

' 

OF  TRAINING-  THE 

THE  ENVIRONMENT  AFFECT IN 

r  1 1  e 

F  A  C I N G  THE  0 R '  'f-^'  I Z  A  T  T  0 N  , 

ll-IAl 

WHICH  THE  ORGANIZATION  1- 

i    ;:?  '  / 

ANY 
T 


STAFF 


TRANS:   (THE  FORMAL  COMPOSITION  OF 

PROMPT:   (IS  THE  STAFF'S  TECHNICAL 

UNKNOWN?) 

expect:  (skilled  unskilled) 
labdata:  t 


THE  ORGANIZATION'S  STRUG  IN'- 
TRAINING  SKILLED.  UNSKILLED 


or; 


STFFTRG 


USED-BY :   (Rules  7  6) 

TRANS:   (THE  STAFF'S  LEVEL  OF  TECHNICAL 

PROMPT:   (IS  THE  ORGANIZATION'S  STAFF'S 

IN  THE  USE  OF  COMPUTERIZED 


TRAINING) 

I  EVEL  OF  IECHNICAL  TR, 

IECHNICAL  AIDS  CONS  ID! 


expect: 
labdata: 


SKILLED.  UNSKILLED. 
(SKILLED  UNSKILLED) 


OR  UNKNOWN''1) 


NG 
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STRESS 


USED-BY J   (Rules  9  8) 

trans:  (the  level  of  the  task's  stress) 
prompt:  cis  the  stress  level  considered 
expect:  (high  lou) 
labdata:  t 


TO  BE  HIGHr  LOWr  OR  UNKNOWN?) 


STYLE 


USED-BY:   (Rules  23  20) 

trans:  (the  leader's  style  of  operation) 

prompt:  (is  the  task  leader's  style  best  described  as 

r  e  l  a  t 1 0  n  -  0  r i e  n  t e d » t a  sk -or  j e n t e d  >   0 r  u n k n 0 w n ? 
expect:  (relation-oriented  task-oriented > 
labdata:  t 

REPROMPT:  (relation  oriented  refers  to  the  leader  who  «i:i. 
direction  t o  hi i s  s t a f f r  e n c o u r a d e s  I h e  s t a 
actively  participate  in  setting  decision  in 
parameters?  and  value-:.-  the  development  of 
r e  s  p  o  n  s  i  b i 1 i  t « «•  T a s  k  o  r  i e n t e d  3 e a  d e r s  are 
as  t ho s e  w h o  p  r  e f  e  r  f a  r  m o  r e  c e n t  r a  1  i z a t  i  o 
c  o  n  t  r  o  1  a  n  d  a  r  e  1  e  s  s  c  o  n  c  e  r  n  e  d  w  i  t  h  t  h  e  d  e 
of  i n d i  v  i.  d u a  1  r e s p o 1 1 s  i b i  1  i  t a  l  n  t h e  dec i s i 
process. ) 


!  i 


1  i  1 1 1  e 


•  i  ii  i  e  j. 

■  f   i  r  i  ■  i 
:■  I" 
■  men  t 

ii   I-  il  r.i 


SYSSTAT 


USED-BY 

trans: 

prompt: 

expect: 

LABDATA 


(RULE036) 
(THE  IMPLEMENTATION/CONSTRUCTION 


S'-ATUS  QF    THE  SYSTEM 


(DOES  AN  OPERATIONAL  SYSTEM  CURRENTLY  EXIST?) 
(YES  NO) 
T 


TRAINING 
USED-BY 

trans: 
prompt: 

expect: 

TRG 


(Rules  25  24) 
(THE  INDIVIDUAL'S  TECHNICAL.  TRAINING 


IN 


(IS  THE  TASK  LEADER" 
TO  BE  HIGHy  L0U» 
(HIGH  LOU) 


I  LEVEL  OF  TECHNICAL 
OR  UNKNOWN?) 


ECISION  ANALYSIS) 
TRAINING  CON'rii  rDERED 


USED-BY :   (RULE002) 

CONTAINED- IN:   (RULE002) 

UPDATED-BY:   (Rules  36  32  31  30  2?  23  27    26  2G  : 

17  16  IS  14  13  ?  0  7  6  5  4  3) 
TRANS:   (THE  RECOMMENDED  TRAINING  OR  ASSISTANCE 
EXPECT:   (HIRE-SPECIALISTS  DO-NOT-HIRE-SPECI ALT! 
STAFF  UNAVAILABLE) 


4  23 


!1  20  1 


L  S 


TO  BE  ACQUIRED' 
IS  TRAIN-EX  I  SI  !'NG 


TYPSYS 


USED-BY :   (RULE002) 
CONTAINED -IN:   (RULE002) 
UPDATED-DY:   (Rules  36  32 
17  16  IS 

trans: 
expect: 


31  30 
14  13 


ncp     op 
9  0  7 


27  26 
6  5  4 


25 

3) 
(THE  TYPE  OF  SYSTEM  RECOMMENDED  TO  BE  U 
(REAL-TIME  NON-REAL-TIME  UNAVAILABLE) 


24 


!3  22  21  20  19  10 


;ed) 
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UNKSTRUC 

UPDATED-BY?   (Rules  33  SREFMARK  34) 
USED-BY:   (RULE034) 
CONTAINED-IN!   (RULE034) 
ANTECEDENT- IN?   (RULE035) 

UPDATED-BY-THE-UAY:   (RULE035) 

TRANS  J   (the  recommended  informal  structure) 

EXPECT:   (CENTRALIZED  DECENTRALIZED  CONSULTATIVE  TRANSACTIONAL 
PARTIALLY-DELEGATED) 
"LPROP-VAL 
"XPROP-VAL 

PROP-VAL 


organization 

trans.'  (the  organization) 

mainprops:  (probtype  formal  informal  stfftrg  leader- trains  <(  style 
proddff  knowledge- level  stress  sysstat  method!  ' 

proptype:  prop-org 

type:  organization- 

ruletypes :  ( orgrules ) 

goals:   (DECAIDS  UNKSTRUC  forstruo 
~LALLNAMES 
"XALLNAMES 

ALLNAMES 


ORGRULES 

CONTEXT:   (ORGANIZATION) 
SVAL:   (ORGANIZATION) 

CTRANS:   ORGANIZATION 
NIL 
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APPENDIX  C 
SAMPLE  CONSULTATION 

BEGIN) 

Special  options  (type  ?  for  help)  J 

**  FT  4 

Instruction's7  (Y  or  H) 

*#  NO 

ORGANIZATIONS 

1)  THIS  PROGRAM  IS  DESIGNED  TO  PROVIDE  MANAGERS  AT  ALL  LEVELS  WITH 
ADVICE  CONCERNING  THE  USE  OF  THEIR  COMPUTER  RESOURCES,   IN 
ORDER  TO  PROVIDE  THIS  INFORMATION*  THE  USER  WILL  BE  ASKED  IT.) 
FURNISH  DATA  CONCERNING:  HIS  ORGANIZATION?  ITS  LEVEL  OF 
TRAINING*  THE  ORGANIZATION'S  LEADER.-  THE  ENVIRONMENT  AFF'-'i  fTNG 
THE  DECISION*  AND  THE  TASK  FACING  THE  ORGANIZATION.   WIIA?  I'S 

THE  TYPE  OF  PROBLEM  WHICH  THE  ORGANIZATION  FACES? 

#*  THESIS 

2)  THE  FORMAL  STRUCTURE  OF  THE  ORGANIZATION  CAN  BE  DEFINED  AS 
EITHER  LINE*  STAFF.  MATRIX.  FUNCTIONAL*  OR  NOTAVAILABLE     :| 

FURTHER  EXPLANATION  OF  THESE  TERMS  IS  NEEDED?  TYPE  A  QUI :TION 

MARK.   WHAT  IS  THE  ORGANIZATION'S  FORMAL  STRUCTURE7 

**  NOTAVAILABLE 

3)  THE  INFORMAL  STRUCTURE  OF  THE  ORGANIZATION  REFERS  TO  THE  MANNER 
IN  WHICH  COMMUNICATION  IS  ACCOMPLISHED,    [S  THE  INFORMAL 
STRUCTURE  BEST  DESCRIBED  AS  CENTRALIZED*  CONSULTATIVE* 
TRANSACTIONAL  *  PARTIAL LY-DELEOATEB -  DECENTRAL IZED «  OP 
NOTAVAILABLE7  IF  FURTHER  EXPLANATION  IS  NEEDED?  TYPE  A  QUESTION 
MARK  . 

**  NOTAVAILABLE 

4)  IS  THE  ORGANIZATION'S  STAFF'S  LEVEL  OF  rECHNICAL  TRAINING  !.N 
THE  USE  OF  COMPUTERIZED  TECHNICAL  AIDS  CONSIDERED  SKILLED? 
UNSKILLED*  OR  UNKNOWN7 

**  SKILLED 

5)  Is  the  task  leader's  technical  training  considered  to  he 
skilled*  unskilled*  or  unknown? 

**  SKILLED 

6)  IS  THE  TASK  LEADER'S  STYLE  BEST  DESCRIBED  AS  RELATION- 
ORIENTED  *  TASK-ORIENTED*  OR  UNKNOWN7 

**  RELATION-ORIENTED 

7)  CONCERNING  THE  PROBLEM  FACING  THE  ORGANIZATION*  IS  THE  PROBLEM 
CLEARLY-DEFINED.  AMBIGUOUS*  OR  UNKNOWN7 

**  CLEARLY-DEFINED 

8)  IN  REGARDS  TO  THE  TECHNOLOGICAL  TRAINING  REQUIRED  TO  ACCOMPLISH 
THE  TASK*  IS  THE  LEVEL  OF  TECHNICAL  TRAINING  CONSIDERED  i"Q  BE 
SKILLED.  UNSKILLED*  OR  UNKNOWN'^ 

**  SKILLED 

?)  IS  THE  STRESS  LEVEL  CONSIDERED  TO  BE  HIGH.  LOW.  OR  UNKNOWN'' 

**  HIGH 

10)  DOES  AN  OPERATIONAL  SYSTEM  CURRENTLY  FXTST^ 

**  NO 

1.1)  ARE  THE  TECHNOLOGICAL  METHODS  USED  ANALYTICAL-AIDS*  INVENTORY- 
AIDS*  OR  UNKNOWN7 

**  ANALYTICAL-AIDS 

— CM  FindoutJ  DECATDS  of  0RGANTZATI0N-2 
Trains!  RIILE002/0RCANIZATT0N-2  ? 

— C2D  Findout:  TYPSYS  of  0RGANIZATI0N-2 
RIJLE036  failed  Cin  preview}  due  to  clause  1 
RULE032  failed  {in  preview}  due  to  clause  1 
RULE031  failed  (.in  preview}  due  t.o  clause  1 
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RULE030  failed  {in  preview)  due  to  clause  1 

RULE029  failed  -Cm  preview}  duo  to  clause  1 

Trains  RULE028/0RGANIZATI0N-2 ?  RULE02S  succeeded. 

Conclude:  TYPSYS  of    ORGAN.TZATION-2  is  UNAVAILABLE  (#5) 

Conclude:  OUTPUT  of  ORGANIZATIONS  is  UNAVAILABLE  (.5) 

Conclude:  INSTALL  of  ORGANIZATION--^  is  UNAVAILABLE  (.5) 

Conclude:  TRG  of    ORGANIZATION-^  is  DO -NUT-HIRE-SPECIALISTS  (.8) 

RULE027  failed  -Gin  preview)  due  to  clause  I 

Trains!  RULE026/0RGANIZATI0N-2  i    RULE026  succeeded. 

Conclude:  TYPSYS  of  ORGANIZATION-?  is  REAL-TIME  (.0) 

Conclude:  OUTPUT  of  ORGANIZATION-?  is  INDIVIDUAI  .-TERMINALS  (.8) 

Conclude:  INSTALL  of  ORGANIZATION--?  is  PYRAMTDAL  (.'-5) 

Conclude:  TRG  of  ORGANIZATION -2  is  UNAVAILABLE  (.8) 

Trains  RULE025/0RGANIZATI0N-2J 

—  Cno  rules  to  conclude  TRAINING  of  ORGANIZATION-^} 

12)  IS  THE  TASK'  LEADER'S  LEVEL  0E  TECHNICAL  TRAINING  CONSIDERED  TO 

BE  HIGH.  LOU.  OR  UNKNOWN? 
**  HIGH 
RULE025  failed  due  to  clause  1 

T  r a  i n S  R U L E 0 24/0 R  G A N I Z  A  T 1 0  N - 2  *  RULEO 2 4  sue c e e  d e d . 
Conclude:  TYPSYG  of  ORGANIZATION-?  is  REAL-TIME  (.96) 
Conclude:  OUTPUT  of  ORGANIZATION  -2  is  INDIVIDUAL -TERMINALS  (.96) 
Conclude:  INSTALL  of  ORGANIZATION-?  is  PYRAMIDAL  (.9) 
Conclude:  TRG  of  ORGANIZATION-?  is  TRAIN -EX  1ST INO-GTAFF  (.8) 
RULE023  failed  Cin  preview}  due  to  clause  1. 
RULEO??  failed  -Cin  preview}  due  to  clause  1 
RULE021  failed  -Cin  preview}  due  to  clause  t 
Trains  RL'LE020/0RGANIZATI0N-2r  RULE020  succeeded. 
Conclude:  TYPSYS  of  ORGANIZATION-?  is  NON-REAL-TIME  (.8) 
Conclude:  OUTPUT  of  ORGANIZATION-?  is  LARGE-SCREEN -DISPLAYS  (.8) 


N-2  i 

5  DIVIS 

I0NAI 

i  s 

TRAIN-EXISTINI 

to 

cl 

a  u  s  e  1 

to 

cl 

a  use  1 

to 

cl 

.j  u  s  e  1 

to 

cl 

a  u  s  e  1 

to 

cl 

3use  1 

to 

cl 

3  u  s  e  1 

...  (  ,  8 ) 

T-STAFF  (.96) 


Conclude:  INSTALL  of  ORGANIZATION 

Conclude:  TRG  of  ORGANIZATION-? 

RULE019  failed  -Cm  preview}  due 

RULEO  13  failed  {.in  preview}  due 

RULE017  failed  Cin  preview}  due 

RULE016  failed  -Cin  preview}  due 

RULE015  failed  Cin  preview}  due 

RULE014  fa'iled  Cin  preview}  due 

Trains!  RULE01.3/0RGANTZATT0N-?;  RIJLE013  succeeded. 

Conclude:  TYPSYG  of  ORGANIZATION-?  is  REAL-TIME  (.99?) 

Conclude:  OUTPUT  of    ORGANIZATION-?  is  INDIVIDUAL -TERMINALS  (. 

Conclude:  INSTALL  of  ORGANIZATION-?  is  PYRAMIDAL  (.98) 

Conclude:  TRG  of  ORGANIZATION-?  is  DO-NOT-H [RE-SPECIALISTS  (. 

RULEO 09  failed  Cin  preview)  due  to  clause  .1. 

Trains  RULE008/ORGANIZATION-25  RULE008  succeeded. 

Conclude:  TYPSYG  of  ORGANIZATION-?  is  REAL-TIME  (.998) 

Conclude:  OUTPUT  of  ORGANIZATION-?  is  INDIVIDUAL-TERMINALS  ( 

Conclude:  INSTALL  of  ORGANIZATION-?  j.s  PYRAMIDAL  (.996) 

Conclude:  TRG  of  ORGANIZATION -2  is  DO-NOT -HIRE-SPECIALISTS  (.992) 

RULE007  failed  Cin  preview}  due  to  clause  1 

Trains  RULE0O6/0RGANTZATI0N-2v  RULE006  succeeded. 

Conclude:  TYPSYS  of  ORGANIZATION-?  is  REAL-TIME  (.999) 

Conclude:  OUTPUT  of  ORGANIZATION-''  is  INDIVIDUAL-TERMINALS  (.999) 

Conclude.'  INSTALL  of  ORGANIZATION-?  is  PYRAMIDAL  (.999) 

Conclude:  TRG  of  ORGANIZATION-2  is  DO-NOT- HIRE-SPECIALISTS  (.990) 

Trains  RULE005/0RGANIZATI0N-2?  RULE005  succeeded. 

Conclude:  TYPSYG  of  ORGANIZATION-?  is  REAL-TIME  (.999) 

Conclude'  OUTPUT  of  ORGAN  I ZA T [ON -?  is  INDIVIDUAL -TERM INALS  (.99?) 


99?) 
96) 

99fl) 


Conclude:  INSTALL  of  ORGANIZATION 


.s  UNAVAILABLE 


75) 


Conclude:  TRG  of  ORGANIZATION-?  is  HIRE-SPECIALISTS  (.6) 
Trains!  RULE004/GRGANIZATI0N-2r  RULE004  succeeded. 

Conclude:  TYPSYS  of  ORGANIZATION-?  is  REAL-TIME  (.999) 
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Conclude:  OUTPUT  of  ORGANIZATION-2  is  INDIVIDUAL-TERMINALS  (,???) 
Conclude:  INSTALL  of  ORGANIZATION -2  is  PYRAMIDAL  (.99?) 
Conclude:  TRG  of  ORGANIZATION-.?  is  DO-NOT-HIRE-SPECIALJPTS  C999) 
RULE003  failed  {in  previewl  due  to  clause  1. 

— C2H  Finished:  TYPSYS  of  DRGANIZATION-2 

--C2:  Findout:  OUTPUT  of  ORGANIZATION-2 

--C2D  Finished:  OUTPUT  of  ORGANIZATION  -2 

--C21    Findout:  INSTALL  of  ORGANIZATION -2 

— £21    Finished:  INSTALL  of  ORGANIZATION-2 

— €21    Findout:  TRG  of  ORGANIZATION -2 

—  £21    Finished:  TRG  of  ORGANIZATION--:? 
RULE002  succeeded. 

Conclude.*  DECAIDS  of  ORGANIZATION -2  is  TEXT  NIL 

USE  THE  FOLLOWING  TYPE  SYSTEM  REAL-TIME 

THE  OUT P l.j T  SHOUL  D  B E  D I SP L  A  Y E D  0 N  I N D I V I D U A  L  •-•  T  ERM I N  A L  S 

THE  MANNER  OF  INSTALLATION  SHOULD  BE  PYRAMIDAL 

AND  THE  RECOMMENDATION  FOR  TRAINING  AND  ASSISTANCE  IS 

DO-NOT-HIRE-SPECIALISTS  .  (1.0) 

— C13  Finished:  DECAIDS  of    ORGANIZATION-2 

antecedent  RULE00.1.  succeeded. 

Conclusions:  THE  DECISION  are  as  follows? 

USE  THE  FOLLOWING  TYPE  SYSTEM  REAL-TIME  THE  OUTPUT  SHOULD  BE 
DISPLAYED  ON  INDIVIDUAL-TERMINALS  THE  MANNEI-  UP 
INSTALLATION  SHOULD  DE  PYRAMIDAL  AND  THE  RECOMMENDATION 
FOR  TRAINING  AND  ASSISTANCE  IS  DO-NOT-HIRE  SPECIALISTS  . 

--C1.I  Findout:  UNKSTRUC  of    ORGANIZATION-2 
Trying  RULE033/0RGANIZATI0N-2J  RULE033  succeeded. 
Conclude:  UNKSTRUC  of  ORGANIZATION-2  is  CENTRALIZED  (.8) 
Trains  RULE034/0RGANIZATIQN-2.  RULE034  succeeded, 
antecedent  RULE035  succeeded. 
THE 

RECOMMENDED  INFORMAL  STRUCTURE  TO  USE  IS  CENTRALIZED. 

Conclude:  UNKSTRUC  of  ORGANIZATION-2  is  TEXT  NIL 

THE 

RECOMMENDED  INFORMAL  STRUCTURE  TO  USE  IS  CENTRALIZED  ': 

—  CI  1    Finished:  UNKSTRUC  of  ORGANIZATION-2 
— CI  3  Findout:  FORSTRUC  of  ORGANIZATION-2 

Trying  RULE039/0RGANIZATI0N-2?  RULE039  succeeded. 
Conclude:  FORSTRUC  of  ORGANIZATION-2  is  LINE  (.8) 
Trying  R  U  L  E  0  4  0 /O R G A N I Z A T 1 0 N - 2 i  R U L E 0 4 0  s u c c e e d e d . 
antecedent  RULE04J  succeeded. 

THE  RECOMMENDED  FORMAL  STRUCTURE  10  USE  IS  LINI 

Conclude:  FORSTRUC  of  ORGANIZATION-2  is  TEXT  NIL 
THE  RECOMMENDED  FORMAL  STRUCTURE  TO  USE  TS  LINE  <1,0> 
--C13  Finished:  FORSTRUC  of  DRGANIZATION-2 


n 
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APPENDIX  D 
ADDITIONAL  EMYCIN/DECAIDS  PARAMETER  PROPERTIES 

Defining  Contexts 

MAINPROPS  -  a  list  of  parameters  to  "trace"  when  3  context  of  this  type  is 
created.   Generally  these  are    labdata  parameters  whose  values  will 
always  be  needed  in  a  consultation  (see  PARAMETERS* DOC  for  a 
definition  of  "labdata").   The  user  will  be  asked  for  the  value  of 
each  of    these  parameters  as  soon  as  a  context  is  created,       This 
often  serves  to  present  3  more  coherent  dialog  than  would  appear 
if  each  parameter  were  reeuested  when  i.  t  was  first  needed  in  a 
rule.   It  is  also  possible  to  have  n  o  n  - 1  a  b  d  a  t  a  par  a  in  el'  e  r  -:.    f  0  r 
ffi3inprops  if  there  is  always  something  you  want  to  deduce  about  a 
new  context.   The  goal  parameter  (s)  of  3  system  will  be  found  in 

the  MAINPROPS  list  of  the  main   (or  root)  context  type?  Lts 
placement  here  is  what  sets  the  consultation  started. 

PROPTYPE  -  an  atom  PROP -type  which  lists  all  parameters  which  pertain 
to  this  type  of  context*  e.g.r  the  PROPTYPE  of  PERSON  in    MYCIN 
is  PRQP-PT*  which  contains  such  parar-eters  as  NAMEr  AGE«  SEX-  etc. 
Ulhen  applying  a  rule*  the  system  uses  this  property  to  tell  which 
context  in  the  tree  3  particular  parameter  belongs  to. 


TYPE  -  an  atom  used  to  form  the  context  identifier  (by  appending  a 

numeral)  for  contexts  of  this  type?  e.g.r  in  MYCIN  the  TYPE  of 
POSCUL  (positive  culture)  is  CULTURE™. 

RULETYPES  -  a  list  of  all  rule  types  applicable  to  this  context  (see 
RULES.DOC)  f    e.g.r  RULETYPES  of  POSCUL  is  the  list  (CULRULES 
POSCULRULES) . 

SYN  -  a  template  used  for  translating  contexts  of  this  type  in 

Questions  or  rules.   The  SYN  property  is  a  list  of  entries 
(<parms>  (form;) r  where  <P3rms>  is  3  list  of  one  or  more 
parameters  of  the  context  1    and  <form>  is  a  simple  list  of  words 
including  the  elements  of  <pa>rms>«  The  parameters  must  appear  in 
the  same  order  in  both  <parms>  and  Storms'  r  arid  they  must  ...'1.1  be 
lab  d  a  t  a  .   The  a  t  o  m  *  is  us  o  d  1  i  k  e  a  p  a  r  a  m  e  t  e  r  1  n  <  p  a  r  m  s '.      -J  n  d 
<form>  to  represent  the  parent  context. 

The  system  scans  the  SYN  property  until  it  finds  an  entry 
for  which  it  knows  the  values  of  all  parameters  in  <parms>5  values 
which  were  not  supplied  by  the  user  will  not  be  used.  Once  an 
element  of  SYN  has  been  selected*  a  translation  will  be 
constructed  by  replacing  each  parameter  in   form>  with  that 
parameter's  value5?  *  will  be  replace  by  the  translation  (using  the 
SYN  property)  of  the  parent  context.  :.>arms>  and  <form!  may  he 
punctuated  with  semicolons  denoting  "places  to  stop"  if  the 
translation  is  unambiguous  so  far.   E.g»*  the  element  from  the  SYN 
property  of  an  organism  ((IDENT  f  *)  (the  IDPNT  ;  from  *))  will 
result  in  "the  Klebsiella"  if  there  are  no  other  organisms  whose 

IDENT  is  Klebsiella*  and  "the  Klebsiella  from  the  blood  culture" 
if  there  is. 

The  simplest  SYN  is  of  the  form  (((pariTi)(psrm)  ))»  i.e.* 

there  is  a  parameter  of  the  context  whose  value  itself  can  stand 
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for  the  context*  e.g.?  (((NAME)  (NAME))).  If  there  is  no  SYN  ptopt 
the  context  identifier  (e.g.?  ORGANISM-1)  will  remain  untranslated, 

UNIQUE  -  For  use  in  conjunction  with  the  SYN  pro*!    it  controls  whether 
the  context  identifier  needs  to  appear  in  the  translation*  e.g. 
a  typical  non-unioue  phrase  is  'the  blood  culture  (CULTURE-2) * r 
since  it  is  possible  to  have  more  than  one  culture  from  the  S3me 
site.   If  the  UNIQUE  property  is  Tf  the  context  identifier  is 
omitted*  e  .  d  .  ?  the  root  context  type  should  have    its  UNIQUE 
property  T.   If  UNIQUE  is  the  atom  '?•>  this  means  to  omit  the 
identifier  if  the  first  try  at  translating  the  context  is.  in 
fact*  unioueJ  e.g.  *  if*  in  the  example  above*  CULTURE-2  were  the 
only  blood  culture  in  the  consult  then  its  translation  would  be 
simple  "the  blood  culture*.   Most  context  types  are  'non-unioue' 
and  will  not  have  a  UNIQUE  property.   The  property  is  not 
necessary  even  on  uniaue  context?  it  exists  simply  to  reduce 
excess  verbiage  where  possible. 


If  your  system  has  no  context  tree?  you  need  only  fill  in  the 
properties  listed  above  for  the  main  (root)  context  type.   If  you  have  3 
non-trivial  context  tree*  however?  it  is  also  necessary  to  supr  I  ..  the 
following  properties  for  non-root  types.'  PROMPT  1ST  (ov    PROMPTEVER )  .» 
PR0MPT2ND*  ASSOCWITU,  and  OFFSPRING. 

PROMPTEVER  -  the  'prompt'  that  will  be  printed  when  the  first  context 

of  this  type  is  created.   Only  context  types  that  will  ALWAYS  be 
created  have  PRQMPTEVERs*  if  you  have  to  ask  whether  there  are 
any  contexts  of  this  type*  then  there  should  be  a  PROMPT  IT!  instead. 
E.g.*  in  MYCIN?  there  is  always  at  least  one  KNOWNORG  under  every 
POSCUL  (by  definition  a  positive  culture  is  one  from  which  organisms 
drew)?  so  KNOWNORG  has  the  PROMPTEVER  (The  first  organism  isolated 
from  *  will  be  referred  to  as :  )  .   CIr.  PROMPTEVER.  PR0MPT1ST? 
and  PR0MTP2ND*  the  *  will  be  filled  in  by  the  parent  context. 3 

PR0MPT1ST  -  the  prompt  asking  whether  contexts  of  this  type  exist. 
Unlike  PROMPTEVER.  this  is  a  real  Question  and  psouirss  ;?n 
answer.   E.g.*   the  PR0MPT1ST  of  CURTMER  is  (Is  *  currently 
receiving  therapy  with  any  anitmicrobial  agent?). 

PR0MPT2ND  -  the  prompt  asking  whether  additional  contexts  of  this  type 
exist  (to  be  used  after  at  least  one  context  of  this  type  has 
been  created).   Omission  of  this  property  indicates  thai  there  is 
never  more  than  one  instance  of  the  context  under  the  i  3 rent 
context.   E.g.*  the  PR0MPT2ND  of  KNOUNORG  is  (Were  any  other 
organisms  isolated  from  *  ?), 

AS30CUITU  -  a  list  of  ancestor  context  types?  showing  this  context 
type's  location  in  the  context  tree.   E.g.  the  ASSOCWITU  of 
KNOUNORG  in  MYCIN  is  (POSCUL  PERSON)  and  the  the  ASSOCWITU  of  POSCUL 
is  (PERSON).   rhis  means  that  a  POSCUL  context  is  directly  below 
the  patient  context?  and  that  a    KNOWNORG  context  is  directly  below 
a  POSCUL. 

OFFSPRING  -  a  list  of  descendent  context  types?  indicating  which  types 

that  can  hang  directly  below  a  context  of  this  type  in  the  context 
tree . 
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Context  types  may  have  other  optional  properties.   If  the  context 
type  is  ever  to  appear  in  a  ruler  it  must  have  a  TRANS  for  translation  (=( 
description  of  a  TRANS  property  in  PARAMETERS . DOC )  .   The  *  in  the  TRANS 
property  of  a  context  type  is  filled  in  by  a  translation  of  the  tree 

root  (main  context).   If. you  plan  to  use  the  SUMMARY  option*  the  context 
type  will  need  a  CNTXTSUMMARY  property  as  described  in  FEATURES .SUMMARY . 
If  paniiaters  of  the  context  type  3re  to  be  fathered  in  a  block  us  i  n-.f 
the  TAB  option  for  tabular  input*  it  will  need  the  TABPARMS*  TABHEAB* 
TERSEHEADr  TABSTOPSi  and  LEGALTERM  properties  as  described  in 
FEATURES. TABULAR-INPUT, 
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Properties  of  Parameters 

Below  is  a  list  of  the  properties  that  a  parameter  can  have. 
All  parameters  need  a  TRANS.  If    the  value  of  the  parameter  is  ever 
reouested  of    the  user*  it  needs  a  PROMPT  and  EXPECT t    and  if  applicable  1 

LABDATA.   Numeric  parameters  should  have  a  CHECK  property r    and  possibly  a 
DEFAULT. 

TRANS  -  how  to  translate  the  parameter.   The  TRANS  is  list?  it    it  contains 
the  atom  *•  the  latter  will  be  filled  with  the  translation  of    the 
context  to  which  this  parameter  belongs  (e.g.  (the  identity  of 
*)).   Special  verbs-  such  as  "is"*  "has"  (all  those  on 
the  list  TRANSVERBS) r  as  well  as  the  word  "not"  should  be  present 
as  low^r-case  literal  atoms  for  correct  translation  of  the 
negation  when  the  parameter  is  used  in  rules* 

PROMPT  -  how  to  ask  for  the  parameter's  value?  no  PROMPT  means  that  it 

makes  no  sense  to  ask  the  user  for  the  value.   The  PROMPT  a  list? 
when  the  Question  is  asked •  the  *  in  the  list  is  replaced  by 
the  translation  of  the  context  being  asked  about?  for 
multivalued  parameters  which  are  not  "ASKALL'r  the  atom  "(valu)' 
is  replaced  by  the  particular  value  be  in. a'  asked  about. 

EXPECT  -  the  set  of  legal  answers  to  Questions  asking  about  this  parameter. 
A  null  EXPECT  is  implicitly  (YES  NO). 

The  most  common  form  of  the  EXPECT  property  is  a  list  of 
the  values  (atoms).   If  an  element  of  the  EXPECT  list  is  itself  a 
list  rather  than  an  atom?  it  will  be  a  list  of  one  element  and 
that  element  is  to  be  evaluated  to  produce  a  list  of  values. 
Usually  the  code  to  be  evaluated  will  be  the  name  of  a  list.   This 
is  useful  when  more  than  one  parameter  will  have  the  same  list  of 
possible  values.   The  code  to  be  evaluated.'  however «  may  be 
arbitrary  Lisp  code  which  produces  a  list.   This  will  be  useful  if 
the  list  of  legal  values  depends  on  some  previous  answer?  e.g.* 
in  MYCINr  valid  answers  for  COLLECT  (method  of  collecting  a 
culture  specimen)  depends  on  STTE?  the  form  evaluated  may 
reference  CNTXT  -  the  object  for  which  you  are  asking?  and  PARM  - 
the  parameter. 

A  few  atomic  EXPECT"-  are  recogrnred ' 
ANY  -  no  restriction  of  the  value 
NUMB  -  the  value?  must  be  a  number 

POSNUMB  -  the  value  must  be  a  positive  number 
DATE  -  the  value  is  a  date 

LABDATA  -  To  you  find  out  the  value  of    this  parameter*  first  try  asking 
the  user.   The  original  meaning  was  that  the  parameter 
was  the  result  of  a  Quantitative  lab  test?  this  has  been  senerali-ed 
to  be  anything  that  the  user  is  likely  to  know.   If  the  user  does  not 
give  3    definite  answer  to  the  Question*  the  system  will  use  rules  (if 
any  exist)  to  deduce  the  value.   For  parameters  that  have  no 
LABDATA  property*  the  system  first  tries  to  conclude  the  value  using 
rules*  and  only  asks  if  no  vulue  was  concluded  (and  a  PROMPT  exists). 
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DEFAULT  -  if  a  numeric-valued  parameter*  the  default  units.   This  allows 
the  user  to  s=ive  the  answer  in  a  different  unit*  and  the  system 
will  convert  it  to  the  default  units.   The  rules  assume  that 
the  value  is  3iven  in  the  default  units. 

CHECK  -  A  form  to  EVAL  to-  make  sure  that  the  user's  numeric  response  is 
•reasonable".  The  CKECK  property  has  the  form.* 

(CHECK  VALU  lowei — bound  upper-bound  text  confirm  integer) 
VALU  will  be  bound  to  the  user's  numeric  response  to  the  Question* 
you  must  supply  the  lower  and  upper  bound.   Text  will  be  printed 
if  VALU  is  not  within  the  indicated  range.   Confirm  can  be  T  or 
NIL:  if  Tr  the  user  may  confirm  that  the  answer  is  correct; 
if    NIL*  an  answer  outside  the  ranrfe  is  always  a  mistake.   Integer 
may  be  T  or    NIL?  if  T»  the  answer  must  be  an  integer. 

MULTIVALUED  -  the  parameter  is  multivalued*   This  means  th3t  it  can  have 

several  different  correct  values  at  the  same  time.   (E.g.*  ALLERGIC 
the  patient  may  be  allergic  to  more  than  one  drug.)   This  is 
different  form  the  normal  case  in  which  the  parameter  Ls  assumed  to 
have  a  single  correct  value?  and  different  values  that  are  concluded 

represent  competing  hypotheses  as  to  the  true  value. 

If  the  value  of  the  MULTIVALUED  property  is  T-  a  separate 
Question  will  be  asked  for  each  value  ( e . S . *  "Is  the  patient 
allerdic  to  penicillin?").   If  the  value  is  the  atom  ASK ALL* 
one  Question  will  be  asked  in  which  tho  user  is  expected  to  Jive 
all  the  values  (e.g.*  "Please  list  all  the  antibiotice  to  which  the 
patient  is  allergic. "  )  ♦ 

The  TRANS  of  a  multivalued  parameter  is  stated  in  the  plural 
(e.g.*  (the  drugs  to  which  *  is  allergic.'1).   This  phrasing  is 
necessary  for  proper  translation  throughout  the  system. 

PROPERNOUN  -  if  the  value  should  be  capitalized  in  translation 

(e.g.*  NAME)*  then  the  parameter  should  have  PROPERNOUN  property  T. 

LEGALVALS  -  Always  the  list  of  all  legal  values  for  this  r-arm*  but  is 
omitted  if  redundant  (which  it  is  for  most  parameters).   All 
multivalued  panns  have  a  LEGALVALS  property.   In  addition  those 
parameters  with  EXPECTs  which  are  pieces  of  code  also  have    one. 
When  a  parameter  has  no  LEGALVALS*  the  legal  values  are  assumed 
to  be  specified  by  the  parameter's  EXPECT  property.   A 
parameter  with  no  EXPECT  or  LEGALVALS  will  be  treated 
as  a  yes/no  parameter i    this  affects  its  translation  in  many 
parts  of  the  system.   The  LEGALVALS  property  may  be  of  the  same  forms 
as  an  EXPECT  property.   Two  atomic  forms  ar^    recognised.   J"ho  atom 
CNTXT  indicates  that  this  parameter  takes  other  contexts  as  its  value 
(e.g.*  in  MYCIN,  the  TREATFOR  property  of  the  patient  is  the 
list  of  all  the  organisms   in  the  context  tree  that  should  be 
treated).   The  atom  TEXT  means  that  the  parameter  takes  arbitrary 
pieces  or  te:;t  as  its  value.   This  will  probably  be  the  case  for 
some  -^oal  parameter  -  the  text  will  be  the  system's  final  analysis 
or  recommendatios . 
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CNTXTVAL  -  To  be  used  when  the  LEGALVALS  is  the  atom  CNTXT.   The  value 
of  this  property  is  a  list  of  PROP-VALs  (context  tapes) 
indicating  that  contexts  of  the  specified  type(s)  can  be 
values  of  this  parameter.   The  value  may  also  be  a  function  of    3 
context  (?>. 

SPECIAL  -  indicates  ambiguous  answers  to  the  PROMPT,  Usually  of  form 
( ( <smbiduous  response'--  <reGijest  for  clarif  ication>)  .  »>) 
M3y  also  be  triples  with  3rd  element  a  default  value  in  case  user 
responds  UNKNOWN. 

XTRASPECIAL  -  indicates  a  response  to  a  Question  that  actual]''  includes 

the  values  for  more  than  one  parameter?  is  usually  a  List  of  lists 
( <<  response. t>  <P3rin.'l  valuel>  <parm2  vaiue2>  etc.)  (<res>-onse2>  etc.) 
meaning  that  the  response  given  should  be  used  to  conclude  the 
values  for  the  parameters?  maw  also  be  ((< response 1>  code)  .  ..) 
meaning  that  the  code  should  be  executed  when  the  response 
has  been  given*  some  entries  are  of  the  form  (-'code.'   r-arm.!  parm2>) 
meaning  that  if  the  code  EVALs  with  the  given  response.-  then  1  new 
value  will  be  indicated--  the  new  value  is  the  value  •     •  -ml  and 
the  user's  response?  is  the  value  for  pa  rnri2  ( e .  g .  r    yes /no  parameters 
when  3n  answer  other  than  yes  or  no  is  given) 

REP PO MPT  -  more  specific  than  original  prompt?  is  printed  out  when  the  user 
enters  "?"  in  response  to  the  oiginal  prompt. 
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APPENDIX  E 
EMYCIN/DECAIDS  PREDICATE  FUNCTIONS 

Non-Numeric  Predicates 


In  all  the  predicates  that  use  v"ALU>   VALU  may  be  omitted  for 
yes/no  paramters.   If  present*  VALU  may  be  an  atomr  a  simple  listr  or  a 
list  of  value-ef  pairs.   The  predicates  SAME  and  THOUGHTNQT  return  numbers 
which  will  be  minimized  by  $AND  to  determining  the  setting  of  TALLY.   The 
other  predicates  return  true   (or  1.000)  or  false  (NIL). 

DEFINITECCNTXTfRARMU 

Returns  true  if  PARM  of  CNTXT  is  known  with  certainty  <cf  =  1.05  for 
yes/no  parameters t    also  ef  -  -1.0). 
Ex:      (DEFINITE  CNTXT  WENT) 

The  identity  of  the  organism  :ts  known  with  certainty 

DEEI S CCNTXT  •  PARh  ,  VALUI! 

Returns  true  if    PARM  of  CNTXT  is  known  with  certainty  to  be  '  -V.i  U 
(cf  =  1.0). 
Ex:       (DEFIS  CNTXT  IDENT  MYCOBACTERIUM-TB) 

It  is  definite  that  the  identity  of  the  organism  is  Mycobaeterium-tb 

DEFNOTCCNTXT  ? PARM  t OALtH 

Returns  true  if  PARM  of  CNTXT  is  definitely  not  YALU  (cf  =  ■  I.  0  :■  , 
Ex:       (DEFN0T  CNTXT  IDENT  VIRUS) 

It  is  definite  that  the  identity  of  the  organism  is  not  Virus 

KNOWNrCNTXTrPARMU 

Returns  true  if  the  value  of  PARM  of  CNTXT  is  known  (cf  .    '.:  '  for 
yes/no  parameters*  also  cf  <  -.2). 
E:<:       (KNOWN  CNTXT  IDENT) 

The  identity  of    the  organism  is  known 

MIGHTBECCNTXTrPARM.OALDl 

True  if  PARM  of  CNTXT  might  be  VALU?  i.e.  there  is  no  evidence  a.s'ainst 
it  (cf  >  -.2)  . 
Ex!       (MIGHTBE  CNTXT  ADEQUATE) 

There  is  no  evidence  that  the  dose  of  the  drug  was  not  appropriate 

NOTDEFINITECCNTXTrPARMl 

Returns  true  if  PARM  of  CNTXT  is  not  known  with  certainty  '  c  i'  1.0? 

for  yes/no  parameters  r    -1.0  <  cf  •''  1.0>. 
Ex:       (N0TDEFINITE  CNTXT  GENUS) 

The  genus  of  the  organism  is  not  known  with  certainty 

NOTDEFISCCNTXT.PARM.OALUl 

Returns  true  if  PARM  of  CNTXT  is  thought  to  be  VALU?  but  nol  with 
certainty  (.2  <  cf  <    1*0). 
Ex:      (N0TDEFIS  CNTXT  IDENT  CRYPT0C0CCUS ) 

It  is  suspected  that  the  identity  of  the  organism  is  cry)  l.ococcus 

NOTDEFNOTT. CNTXT.  P ARM  rVALUD 

Returns  true  if  PARM  of  CNTXT  is  thought  not  to  be  VALUr  but  not  with 
certainty  (-1.0  <  cf  <  -.2). 
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Ex:      (NOTDEFNOT  CNTXT  IDENT  E.COLI) 

It  is  suspected  that  the  identity  of  the  organism  is  not  E.coli 
NOTKNOWNCCNTXT ,  PAPM.l 

Returns  true  if  FARM  of  CNTXT  is  not  known  (cf  <=  .2?  for  ues/na 
parameters*  -.2  <=  cf  <=  .2). 
Ex.*      (NOTKNOWN  CNTXT  -IDENT) 

The  identity  of  the  organism  is  not  known 

NOTSAMECCNTXT r FARM r VALUD 

The  logical  compliment  of  SAME*  returns  true  if  FARM  of  CNTXT  is  not 
thought  to  be  VALU  (cf   <~    .2). 
ExJ      (NOTSAME  CNTXT  SPECSTAIN) 

OrSanisnis  were  not  seen  on  the  stain -of  the  culture? 

ONCEKNOWN C CNTXT  *  FARM > RETFLG. 1 

Finds  the  value  of  FARM  of  CNTXT.   If  RETFLG  is  NILr  it  means  "you  have 
found  a  value  for  FARM  of  CNTXT"!  returns  the  seme  as  KNOWN  would*   If 
RETFLG  is  Tr  it  means  'find  out  all  you  can  about  FARM  of  CNTXT"?  this 
causes  tracing*  but  ONCEKNOWN  will  return  true  even  if  nothing  was  found 
"Lemycin.doc  Page  85 


out.    Intended  to  be  invoked  last  among  the  updated-by  rules  of  FARM. 
Ex:      (ONCEKNOWN  CNTXT  SAMEEUG) 

There  is  an  organisms  with  possibly  the  same  identity  as  this 
organism 

ONCEKNOWN* CCNTXTrPARMSH 

Traces  FARMS  of  CNTXT  and  returns  T  regardless  of    the  result  of  this 
tracind.   This  is  like  calling  ONCEKNOWN  repeatedly*  once  for  each  parameter 

in  FARMSr  with  RETFLG  set  to  T  in  the  calls. 
.Ex?      (ONCEKNOWN*  CNTXT  (QUOTE  (CURTHER  PRIORTHER))) 

Information  has  been  gathered  about  current  drugs  of  the  patient 
and  prior  drugs  of  the  patient 

SAMEL'CNTXT  ,  FARM  ,  UALU1 

Checks  to  see  if  FARM  of  CNTXT  is  VALU  returning  the  associated  cf. 
Always  returns  a  number?  in  a  rule*  HAND  will  consider  the  clause  "true" 
if  this  number  Greater  than  .2. 
Ex:      (SAME  CNTXT  SITE  BLOOD) 

The  site  of  the  culture  is  blood 

3THOUGHTNOTCCNTXT»PARM»VALU3 

Checks  to  see  if  FARM  of  CNTXT  is  not  VALU*  i.e.*  there  is  evidence 
aaainst  it.   Always  returns  a  number?  in  a  ruler  $AND  will  consider  the 
clause  'true'  if  this  number  greater  than  .2.   The  number  that  is  returner 
is  the  negative  of  the  cC    associated  with  the  triple  (CNTXT  FARM  VALU) t 
so  the  clause  will  be  true  if  the  cf  associated  with  that  triple  is  less 
than  -.2.   This  is  the  algebraic  negation  of  SAME?  whereas  NOTSAME  is 
the  losicnl  negation* 
Ex!      CTHOUGHTNOT  CNTXT  IDENT  E.COLI) 

There  is  evidence  that  the  identity  of    the  organism  is  not  E.coli 
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VNOTKNOWNCCNTXT * PARM  * VALU] 

Returns  true  if  it  is  not  known  whether  the  value  of  PARM  of  CNTXT  is 
(or  is  not)  VALU  (-.2  <=  cf  <=  .2), 
Ex:      (VNOTKNOWN  CNTXT  IDENT  E.COLI) 

It  is  not  known  whether  the  identity  of  the  organism  is  E.col i 


Numeric  predicate  functions 


There  are  five  numeric  predicate  functions  to  be  used  with  parameter! 
which  take  numbers  or  dates  as  their  values.   A  parameter  with  DATE  for  it; 
EXPECT  f-rof-prt'j    accepts  a  date  as  input *  but  internally  stores  the 
answer  as  the  number  of  days  ado  (or  since  the  time  of  the  ci  i  Sinai 
consultation  for  stored  cases).   The  Lisp  functions  PLUS*  DIFFERENCE* 
MINUS*  TIMES*  FQUOTIENT*  and  EXPT  ha^j&    translations  in  case  they  ;re  used 
within  these  numeric  predicates.   The  translations  of  numeric:  expressions 
can  be  very  wordy.   To  have  an  expression  translated  tersely  (using 
arithmetic  operator  symbols  instead  of  text)*  enclose  the  expression  in 
a  call  to  the  function  TRSEXP. 

BETWEEN*CVALU*LLIM*ULTMJ 

True  if  LLIM  ^  VALU  <  ULl'M 
Ex.*      (BETWEEN*  (VAL1  CNTXT  AGE)  10  50) 

The  aSe  of  the  patient  :i. s  between  10  years  and  50  years 

GREATEQ*CX*Y1 

True  if  X  and  Y  are  numbers  and  X  >=  Y. 
Ex:      (GREATEG*  (VAL1  CNTXT  NUMPOS)  2) 

The  number  of  cultures  from  this  site  which  were  positive  for  this 
organism  is  greater  than  or    eeual  to  2 

greaterp*cx*y:j 

True  if  X  and  Y  sre    numbers  and  X  >  Y. 
Ex.*      (GREATERP*  (VALl  CNTXT  CSFGLUC)  SO) 

The  csf  Slucose  value  is  greater  than  80 

lesseq*cx*y: 

True  if  X  and  Y  are  numbers  and  X  <■-  Y, 
Ex:      (LESSEQ*  (VAL1  CNTXT  CSFGLUC)  SO) 

The  csf  glucose  value  is  less  than  or  eoual  to  80 


lessp*cx*y: 

True  if    X  and  Y  are  numbers  arid  X  ■'.    Y. 
ExJ      (LESSP*  (VAL1  CNTXT  CSFGLUC)  00) 

The  csf  glucose  value  is  less  than  to  SO 
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Conclusion  Functions 

The  functions  in  a  rule's  ACTION  concludes  about  one  or  more 
eontext-parameter-value  triple.   A  cf  for  the  triple  is  specified  in  the 
rule's  ACTION.   This  cf  will  be  modified  by  the  certainty  of  the  rule's 
PREMISE.   *AND  sets  TALLY  to  the  certainty  of  the  PREMISE*  defined  to  be 
the  minimum  of  the  values  (numbers)  returned  by  evaluating  the  PREMISE 
clauses  (only  SAME  and  THQUGHTNQT  return  numbers). 

If  a  triple  already  exists*  this  new  cf  is  "combined"  with  the  c^ 
associated  with  that  triple.   Otherwise*  the  new  cf    itself  is  associated 
with  the  new  triple. 

CONCLUDECCNTXT  * PARM  *  VALUE  *  TALLY  * NUMU 

Concludes  that  PARM  of  CNTXT  is  VALUE.   The  conclusion  made  by  this 
call  will  have  3  cf  that  is  TALLY  times  NUM. 
Ex:      (CONCLUDE  CNTXT  CONTAMINANT  YES  TALLY  400) 

There  is  weakly  suggestive  evidence  (.4)  that  the  organism  is  a 
contaminant 

CONCLUDE* C CNTXT y  PARM*  TALLY*  VALS.1 

Performs  multiple  CONCLUDE 's  for  a  single  CNTXT  and  PARM.   MALL'S  is  a 
list  of  pairs  (value  of ) *  e 3ch  value  is  c o n c 1 u d e d  wit h  t h e  c orr e s i  < ; n d i n g 

cf . 

Ex!      CCONCLUDE*  CNTXT  IDENT  TALLY  (QUOTE  ((E.COLI  400) 

( KLEBSIELLA- PNEUMONIAE  300) 
(PROTEUS  ■■■HIRADIL  IS  300j 
There  is  evidence  that  the  identity  of  the  organism  is  e  coli  (.4) 
klebsiel la-pneumoniae  (.3)  proteus-mirabilis  (.3) 

CONCLUDETUCNTXTrSWITCHNUMr CASE* TALLY y PARM. VALUS j 

Tabular  rule  concluding  fn.   Concludes  that  PARM  of  CNTXT  is  one  or 
more  of  the  values  in  VALUS*  according  to  the  value  of    SUITCHNUM. 

SUITCHNUM  is  a  form  to  evaluate  which  must  return  a  number.   Tt  is 
generally  a  call  to  VAL1  for  some  numeric  parameter. 

VALUS  is  a  list  (VAL1  VAL2  ...  VALn)  of    values  for  PARM. 

CASE  is  a  list  of  cases  which  test  SUITCHNUM  and  supply  cfs  for 
the  values  in  VALUS  that  is  to  be  concluded.   Possible  cases  currently  are  5 

(LT  NUM  CF1  CF2  ...  CFn)   if  SUITCHNUM  <  NUM  *  conclude  tha1".   PARM  is 
VALi  with  cf    CFi * 

(BT  NUM1  NUM2  CFI  CF2  ...  CFn)  if  NUM1  <=  SWITCHNUM  <  NUM2-  conclude 

th3t  PARM  is  VALi  with  cf    CFi? 
(GE  NUM  CFI  CF2  ...  CFn)  if  NUM  <-  SWITCHNUM*  conclude  that  PARM 

is  VALi  with  cf    CFi* 
(U  CFI  CF2  ...  CFn)  if  SUITCHNUM  =  NIL.  conclude  that  PARM  ls 
VALi  with  cf  CFi r 
Each  CFi  must  be  included  in  each  case*  if  a  particular  value  doesn't 
apply?  the  c o  r  r e s p o n d i  n g  c f  c a n  be  0 . 
Ex.'      (CONCLUDET  CNTXT  (VAL1  CNTXT  LENSIGN) 

(QUOTE  ((BT  9    13  -400  -500) 
(BT  13  20  -300  -400) 
(GE  20  600  300)  )  ) 
TALLY  TYPE  (QUOTE  (BACTERIAL  VIRAL))) 
The  type  of  the  infection  is  as  follows.' 

If  the  duration  of  the  neurological  signs  is  J 

a)  between  9  days  and  13  day.  then:  not  bacterial  (.4).  not  viral  (.5)* 

b)  between  13  days  and  20  days  then.*  not  bacterial  (.5)*  not  viral  (  .  4  )  •' 

c)  slreater  or  eaual  to  20  '(ays  then*  bacterial  (.6)r  viral  (.3)* 
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CONCLUDETEXT  TCNTXT  * FARM * VALUE  * TALLY  * NUM3 

This  function  C3lls  CONCLUDE  for  parameters  whose  values  are  arbitrary 
peices  of  text.   It  is  3  different  function  because  it  translates 
differently. 

DO-ALLCX:  NL* 

For  multiple  conclusions  -  evaluates  each  of  its  arguments  (rule 
conclusions ) . 
ExJ      (DO-ALL  (CONCLUDE  CNTXT  IDENT  LISTERIA  TALLY  500) 

(CONCLUDE  CNTXT  GENUS  CORYNEBACTERIUM  TALLY  300) 

1)  There  is  suggestive  evidence  (.5)  that  the  identity  of  the 

organism  is  Listeria)'  and 

2)  There  is  suggestive  evidence  (.5)  that  the  genus  of  the 

organism  is  Corynebacter  ium" 

DONTASKTCNTXTfPARMl 

Conclusion  function  which  saws  that  FARM  of  CNTXT  should  not  be  asked 
(although  it  may  be  traced*  if  needed)* 


Ext      (DONTASK  CNTXT  CONFORM > 

Don't  3sk  about  the  Growth  conformation  of  the  organism 

NOTRELEVANf CNTXT. FARMS rCFl 

A  conclusion  function  that  indicates  that  the  value  of  e3Ch  of  the 
parameters  in  PARMs  is  not  relevant  for  CNTXT!   we  shouldn't  ever  ask  or 
try  rules  to  deduce  the  value. 
Ext      (NOTRELEVANT  CNTXT  (QUOTE  (SECONDARY))  1000) 

It  is  definite  (1.0)  that  the  following  is  irrelevant.'  the 
infection  to  which  the  bacteremia  is  secondary 

PRINTCONCLUS  IONS  C  CNTXT  r  FARM.  HEADER.! 

Displays  nicely  the  value  of  FARM  of  CNTXT »  or  indic3tes  that  no 
conclusions  were  made.   Intended  as  a  simple  goal  rule  ACTION.  If  HEADER 
is  T*  prefixes  values  with  a  simple  header  announcing  what  these  ar&    the 
values  of)  if  other  non-NIL  value?  HEADER  is  printed?  otherwise  no  header 
3t  all  is  printed*  and  nothing  is  mentioned  if  there  are  no  values. 

Special  facility  for  use  ui th  TEXT-valued  parms:  if  FARM  has  a 
property  LADEL . ORDER »  then  TEXT  values  of  eoual  cf  will  be  sorted  by  their 
l3bels.   For  LABEL .0RDER-T*  the  labels  are  integers*  and  the  values  will 
be  sorted  in  ascending  order  of  label*  otherwise  the  LAPEL. ORDER  property 
is  a  list  of  labels  (atoms),  and  the  values  ave    sorted  according  to  the 
order  of  the  labels  in  this  list. 
ExJ      (FRINTC0NCLUSI0NS  CNTXT  REGIMEN) 

Display  the  therapeutic  regimen  of  the  patient 

Auxilliary  functions 


$ANDCi$CLAUSESl  NL* 

Evaluates  eac.\i    of  the  predicates  in  *$CLAUSES  until  one  fails*  if  all 
succeed  (i.e.  return  T  or  a  cf  >  .2)  the  minimum  cf  is  returned*  else  NIL 
All  rule  premises  and  the  predicates  of  all  mapping  functions  must  be 
calls  to  HAND  -  even  if  there  is  only  a  single  predicate  clause  inside 
the  HAND. 
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$ORC*$ CLAUSES}  NL* 

Evaluates  each  of  the  predicates  in  ^CLAUSES*  returning  the  e.f.  of  the 
most  hishly  confirmed  clause?  unless  all  fail.   Stops  if  one  of  the  clauses 
evaluates  with  certainty  (since  the  maximum  1.0  is  the  result). 
Ex*         <$0R  (GREATERP*  (VAL1  CNTXT  WBC)  12.5) 

(GREATERP**  (VAL1  CNTXT  PMNS)  80) 

(GREATERP*  (VAL1  CNTXT  HANDS)  10)) 

1)  The  white  count  from  the  patient's  peripheral  CBC  (in 

thousands)  is  Greater  than  12. 5 t    or 

2)  The  percent  of  PMN '  s  in  the  CBC  is  greater  than  80  k  or 

3)  The  percent  of  peripheral  WBC's  which  are  immature  in  the  CBC  is 

Greater  than  10 

listofcn:  l* 

Simp-la  EVALs  its  argument  (which  is  usually  the  name 
as  argument  to  a  basic  predicate  when  a  choice  of  values 
Ex.*      (SAME  CNTXT  SITE  (LIST0F  STERILESITES)  ) 

The  site  of  the  culture  is  one  of*  those  sites  tl 
sterile 

0NE0FCXD  NL* 

A  no-spread  auoteJ  returns  its  argument  list.   Used  as  argument  to  a 
basic  predicate  when  a  choice  of  values  is  indicated. 
Ext      (SAME  CNTXT  SITE  (0NE0F  URINE  SPUTUM)) 

The  site  of  the  culture  is  one  eft  urine  sputum 

quotecx:  nl* 

Lisp  function.   It  is  used  in  action  functions  that  reauire  a  list  of 
parameters?  values?  etc.  (e.g.?  CONCLUDET). 

TEXTCN3  L* 

Constructs  value  of  TEXT-valued  parms.  The  first  argument  i<n  a  label 

(or  NIL)  which  may  be  used  to  tag  the  value  for  sorting  by  PRINTC0NCLUSI0NS 

The  remaining  arss  3re  arbitrary  rule  forms  to  construct  a  text  Phrase* 

Result  is  a  list  (TEXT  label  .  Phrase).   If  there  is  only  one  arg»  the 
label  is  interpreted  as  a  TEXT  tag?  i.e.  (TEXT  label)  is  the  same  as  (TEXT 
label  (TEXTAG  label)). 


TEXTAGCTAGH  NL 

Quotes  a  text  "tag"?  a  place  holder  for  a  string  of  text  which  is  the 
"value*  of  a  conclusion  parameter.   TAG  should  be  in  PROP-TEXT,  and  should 
have  a  TRANS  which  is  the  string  in  Question  (at  least  in  current 
implementation) . 


UNITSCUD  NL* 

Returns  its  first  argument.   The  second  argument  is  not  seen  bu  the 
function?  but  is  a  unit  and  is  used  for  translation. 
Ex.*      (GREATERP*  (VAL1  CNTXT  AGE)  (UNITS  3  YEARS)) 

The  ase  of  the  patient  is  greater  than  three  years 

VALCCNTXTfPARMD 

Returns  PARM  of  CNTXT  as  a  list  of  pairs  (value  cf)?  tracing  the 
parameter  first  if  it  has  not  been  traced  yet. 
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VALlTATMrPARMJ  ML 

Returns  the  value  of  FARM  of  ATMr  without  its  cf .   Only  suitable  for 
single-valued  parameters.  ATM  is  evaluatedr  FARM  is  not. 

VALYEWCCNTXTrPARM: 

Returns  PARM  of  CNTXT  as  a  list  of  pairs  (value  cf)     in  order    of 
decreasing  cf.   This  is  the  same  as  returned  by  VAL  if  the  parameter  has 
already  been  traced.   VALYEW  causes- no  tracing?  it  can  be  interpreted  as 
the  system's  current  information  about  PARM  of  CNTXT 


Mapping  functions 

You  probably  won't  need  to  use  mapping  functions  in  any  of  your 

rules.   The  exist  to  allow  a  rule  to  use  parameters  of  the  context. 

to  which  the  rule  is  applied"  as  well  as  parameters  of  e3ch    of         specified 

list  of  contexts. 

The  functions  map  o^er    a  list  $$MAPSET  which  is  usual!.''    List  of 
contexts.   $$FREEVAR  is  the  name  of  the  iteration  variable?  it  i  ■:  not 
necessary  to  specify  a  value  for  $$FREEv"ARj  the  default  FREEVAR  will  be  used 
if  none  is  specified.   'PURRED  is  a  predicate  which  has  the  same  form  as 
a  rule  PREMISE.   Clauses  in  f»$PRED  may  use  CNTXT  (the  context  to  which  the 
rule  is  being  applied)  as  well.  3S  FREEVAR  in  their  context  slo"l 
If  $$ MAP SET  is  a  list  of  pairs  (which  it  will  be  if  the  set  is  the  result 
of  a  call  to  GETALL  or  GETGFFSPRING)  t     the  CARS  flag  should  be  set  to  T. 
This  indicates  that  each  time  ft'tFREEVAR  should  be  set  to  the  CAR  of  the 
current  element  rather  than  the  element  itself.   Most  of  the  functions 
return  $  $  A  N  S  ET  set  to  t  h  e  i.  r  r  e  s  u  1 1 .   F  o  r  f  u  n  c  t  :i  o  n  s  w  h  o  s  e  r  es  u  I  t  i.  &  3  1 1  s  t  r 
COLLECTEDLST  is  the  default  for  $$ANSET?   for  those  that  return  3  single 
element  r  the  default  is  FQUNDv'AR*   These  result  variables  av^    global?  the 
result  of  a  mapping  f  u n c t  i  o n  i  n  a  r  1 1 1,  e  '  s  P R E M 1 3 E  1  s  o  f  t  an  u s  e d  in  t h 3  t 
rule's  ACTION. 

A  m a p p  i n g  f  u n c t  i  o n  c a n  h e  e >ri b e d d  1  n g  1  n  a  c  3  1. 1.  to  t h e  I...  I c- P  f  u n c  t i a n 
N 0 T  r    and  the  action  a n d  translatio n s  w i  1 1  b e  a p p  r o ■■  <- 1  a  1 1  y  n e g a  t  e  d . 


FINnMAXC!T»$MAPSETr$*PREDT$$TEST»$i;FREEVAR^$$ANSET»CARS3  NL 

Mapping  function  that  returns  T>T>ANSET  set  to  the  element  of  MMAPSET 
which  had  the  largest  value  of  $$TEST  out.  of  all  those  elements  which 
satisfied  *$PRED.   Global  MAXUAL  is  set  to  this  maximum  value  uf  INVEST. 

Ex?   .    (FINDMAX  (GETALL  CURTHER) 

(*AND  (KNOWN  PFREEDRUG  WIIENSTART)  ) 
( V  A L 1  * F R E E D R UG  W  H E N S TART ) 
f-FREEDRUG  NIL  T) 
You  have  examined  the  current  drugs  of  the  patient  for  which  the 
1 1  m  e  sin  c  e  t  h  e  imp  y  w  1 1  h  t  h  is  d  r  u  g  w  a  s  s  t  a  r  t  cd  is  kn  o  w  n  r 
and  have  selected  the  one  having  the  maximum  value  for  the 
time  since  therapy  with  this  drug  was  started 
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FINEiMINC$$MAPSET*$$PRED*$$TEST**$FREEv'AR,*$ANSETrCARS:]  NL 

Like  FINDMAX*  but  looks  for  the  the  smallest  value  of  *$TEST*  and  sots 
alobal  MINVAL. 
Ex:      (FINDMIN  (GETALL  PRIORTHER) 

($AND  (LESSEQ*  CVAL1  *FREEBRUG  UHENSTOP)  5)) 
(VAL1  $FREEDRUG  UHENSTOP) 
*FREEDRUG  NIL  T 
You  h3ve  examined  the  prior  drugs  of  the  patient  for  which  the 

time  since  therapy  with  this  drusJ  was  discontinued  is  less 
than  or  eoual  to  u    daysr  and  have  selected  the  one  having 
the  minimum  value  for  the  time  since  therapy  with  this 
drug  was  discontinued 

F0RALLC$$MAPSETf$*PREDr$$FREEVARfCARS3  NL 

True  if  $T>PRED  is  true  for  each  element  of  $$MAPSET.  Function  returns 
(trivially)  true  if  map  set  is  empty. 
Ex  J      (FORALL  (GETALL  POSCUL)  ($AND  (NOTSAME  FREEVAR  SPECSTAIN) 

(NOTSAME  FREEVAR  CRYPTO-SERGLGGY) 
(NOTSAME  FREEVAR  COCCI-SEROLOGY > ) ) 
For  each  of  the  the  positive  cultures  of  the  Patient  it  is  true  that 

1)  Organisms  were  not  seen  on  the  stain  of  this  culture* 

2)  The  cryptococcal  antigen  in  the  esf  was  not  PO-.-iiti.ver  and 

3)  The?  csf  coccidioides  serology  was  not  positive 

THEREAREC*$MAPSET*$*PREB*  *$FREEVAR*$$ANSET*CARS*  DUPLES1  NL 

Collects  all  the  elements  of  $*MAPSET  for  which  f.tPRED  is  true* 
If  DUPLES  is  Tr  it  returns  a  list  of  duples  pairing  each  element 
of  $$MAPSET  that  succeeded  with  the  value  (number)  returned  when 
the  predicate  was  appliedto  that  element. 
Ext  (THEREARE  (GETALL  KNGUNGRG  ) 

($AND  (DEFINITE  CNTXT  IDENT)) 

NIL  COLLECTEDORGS  D 
You  h3ve  examined  the  organisms  isolated  from  positive  cultures 

obtained  from  the  patient*  selecting  those  for  which  the 

identity  of  the  organism  is  known  with  certainty 

THEREARE! CND  L* 

Returns  true  if  LST  is  non-empty,   This  is  like  a  call  to  THEREARE  with 
**MAPSET  Tr  but  translates  better. 
ExJ      (THEREARE!  (GETOFFSPRING  CNTXT  SMEARORG)) 

There  are  organisms  noted  on  smears  of  this  culture 

THEREXISTSC$$MAPSET***PREDr*$FREEVAR*S$ANSET*CARS3  NL 

Like  THEREARE*  but  Just  finds  the  FIRST  element  (or  CAR  of  element) 
satisfying  *$PRED»  and  returns  that. 
Ex.*      (THEREXISTS  (GETALL  CURTHER) 

($AND  (SAME 'FREEVAR  DNAME  (ONEOF  AMPICILLIN  CARDENTC ILLIN 

PENICILLIN  METHIC ILLIN) > ) 
NIL  NIL  T) 
You  have  examined  current  drugs  of  the  patient*  and  have ^ found  one 

for  which  the  name  of  this  drug  is  one  of  I  ampicillin 
carben ici 1 1  in  pen i c i 1 1  i n  me th i ci 1 1 i n 
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Functions  used  within  Mapping  Functions 

getalltctype:  nl 

Returns  a  list  of  all  contexts  of  type  CTYPE.   Currently  in  the  form 
((cntxt  1000)...  )t    until  we  get  around  to  being  neater.   This  is  often  used 
in  the  $$MAPSET  slot. 

GETOFFSPRINGCCNTXTrTYPEl 

Returns  a  list  of  contexts  of  type  TYPE  descendant  to  CNTXT    Currently  a 
list  ((cntxt  1000)  ...). 

appendcl:  l* 

Lisp  function.   It  is  used  in  the  *$MAPSET  slot  when  more  than  one 
type  of  context  is  to  be  examined. 

N0TSAMEANSCCNTXT1 T CNTXT2»FARM3 

Premise  clause  which  is  true  if  CNTXT1  arid  CNTXT2  have  different  values 

SAMEANSCCNTXT1 r CNTXT2* PARM3 

A  premise  function  that  is  true  if  CNTXT.1.  and  CNTXT2  have  the  same  value 
for  parameter  FARM. 

TRACEDPCCNTXTrPARil"! 

True  if  FARM  has  been  traced  for  CNTXT.  This  is  used  when  the 
value  of  a  parameter  of  one  context  is  to  be  transferred  to  another  context. 
To  avoid  circular  reasoning  we  specify  that  the  target  parameter  must 

already  be  traced  for  a  context  to  satisfy  the  predicate. 
ExJ      CTHEREXISTS  (APPEND  (GETALL  P0SCUL)  (GETALL  PENDCUL) ) 
($AND    (TRACEDP  FREEVAR  NOSOCOMIAL) 
(KNOWN  FREEVAR  NOSOCOMIAL) 
(SAMEANS  CNTXT  FREEVAR  SITE)) 
NIL  F0UNDCUL  T) 
You  have  exar.ined  positive  cultures  obtained  from  the  patient  arid 

pending  cultures  of  the  patient?  and  Knmve    found  one  for  which 

1)  All  information  about  whether  the  infection  was 

acquired  while  the  patient  was  hospitalised  has 
been  gathered r    and 

2)  It  is  known  whether  the  infection  was  acouired  while 

the  patient  was  hospitalized?  and 

3)  The  culture  under  consideration  arid  this  culture  have  the 

same  value  for  the  site  of  the  culture 

Action  Functions  used  in  Rules  with  Mapping  Functions 

C0NCL I  ST C CNTXT t P ARM >GVAL> TALLY  J 

GVAL  is  a  list  of    duples • (value  cf).   Concludes  that  FARM  of  CNTXT  is 
each  of  those  values?  modified  by  TALLY, 
ExJ       (C0NCLIST  CNTXT  IDENT  GRIDVAL  900) 

There  is  stronsly  suggestive  evidence  (.?)  that  each  of  the  ones 
that  you  found  is  the  identity  of  the  organism 

CONCLUDEALLCCNTXTSrPARM^ALU'CFl 

Makes  the  same  conclusion  for  each  of  a    list  of  contexts. 
Ex:      (CONCLUDEALL  COLLECTEDCULS  REQTHER  YES  -1000) 

It  is  definite  (1,0)  that  the  organisms  isolated  from  the  cultures 
that  you  selected  should  not  be  considered  for  therapy 
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TRANSDIFPARMCFROM! .FPARMfTO! • TP ARM ,CFf POSITIVE: 

Transfers  the  value  of  FPARM  of  FROM!  to  TPARM  of  TO ! t    modified  by  CF. 

Either  FROM'  or  TO!  may  be  a  list  of  contexts  or  a  single  context.   FPARM 

and  TPARM  are  different  parameters.   If  POSITIVE  is  set*  it  only  transfers 

values  with  non-negative  CFs . 

Ex.*      CTRANSDIFPARM  COLLECTEDORGS  IDENT  CNTXT  COVERFOR  700) 

There  is  suggestive  evidence  (.7)  that  the  identity  of  each  of  the 
organisms  that  you-  selected  is  the  organisms  (other  than 
those  seen  on  cultures  or  smears)  which  might  be  causing 
the  infection 

TRANSLISTCFROM» TO t FARMS t  11 

Transfers  to  context  TO  the  values  of  of  each  of    the  PARMS  of  the 
contexts  in  FROM*  modifying  the  cf  s  by  I. 

Ex:      CTRANSLIST  (VALYEU  CNTXT  SAMEEUG)  CNTXT  (QUOTE  (IDENT))  1000) 
It  is  definite  (1.0)  that  these  properties  -  ident  -  should  be 
transferred  from  the  organisms  with  possibly  the  same 
identity  as  this  organism  to  this  organism 

TRANSPARMCFROM! .TO' rPARMyCFD 

Transfers  the  value  of  FARM  of  FROM!  to  TO ! i  modified  by  CF.  Either 
FROM'  or  TO!  may  be  a  list  of  contexts  or  a  single  context.  If  POSITIVE 
is  set>  only  transfers  values  with  non-negative  CFs. 

Ex:       (TRANSPARM  FOUNDCUL  CNTXT  SECONDARY  1000) 

It  is  definite  (1.0)  that  the  information  that  you  have  gathered 
about  the  infection  to  which  the  bacteremia  is  secondary 
is  also  relevant  to  this  culture 
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APPENDIX  F 
DECAIDS  USER'S  PROCEDURES 

In  order  to  present  the  procedures  necessary  to  use  the 
DECAIDS  prototype  decision  support  program,  the  following  quick 
reference  material  is  provided.   All  TOPS- 20  and  EMYCIN/ 
DECAIDS  commands  must  be  followed  by  a  carriage  return  to 
enter  the  user  command  or  response.   A  sample  consultation 
is  presented  in  Appendix  C. 

1.  Select  the  desired  ARPANET  compatible  terminal  to 
be  used. 

2.  Connect  to  the  local  ARPANET  TIP. 

3.  If  using  dial-up  device,  upon  receiving  the  carrier 
tone,  connect  the  telephone  to  the  terminal's  modem. 

4.  Depress  the  "RETURN"  key  once. 

5.  The  following  will  be  printed  by  the  system: 

NPS  TIP  420#:   2 

6.  The  user  next  enters 

§1  116 
This  will  connect  the  user  to  the  University  of  Southern 
California's  Information  Sciences  Institute  System  E  computer 
referred  to  as  ISIE. 

7.  The  system  will  respond  with: 

TRYING  . . . 

OPEN 

ISI-SYSTEM-E.   TOPS-20  MONITOR  3A(105) 

e 
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The  "@"  symbol  is  the  TOPS-20  operating  system's  prompt. 
After  this  symbol,  a  user  may  enter  his  commands  or  responses. 

8.  The  user  next  enters: 

LOG  DECAIDS  escape 

9.  On  the  same  line  with  the  last  entry,  the  user 
will  be  challenged  with: 

(PASSWORD) 

10.  The  user  must  respond  to  (PASSWORD)  with: 

"PASSWORD"  escape . 
(The  actual  password  may  be  obtained  from  LTCOL  R.  J.  Roland 
or  Professor  Gary  Poock.) 

11.  Again  on  the  same  line  as  above,  the  user  will  be 
challenged  with: 

(ACCOUNT) 

12.  The  user's  proper  response  to  (ACCOUNT)  is  to  enter 
a  carriage  return. 

13.  The  current  TOPS-20  operating  system  will  respond  with 
accounting  data,  date,  and  user  file  information.  This  infor- 
mation may  be  viewed  or  terminated  with: 

Control  0 

14.  At  the  end  of  the  login  information  the  "@"  prompt 
will  be  returned  by  the  TOPS-20  operating  system.   At  any 
time  after  logging  in  has  been  completed,  the  user  may  enter 
a: 

Control  C 
in  order  to  return  to  an  "@"  prompt  and  thereby  facilitate  a 
quick  log-off  with  the  command: 
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LOGO 

15.  To  enter  the  EMYCIN/DECAIDS  system,  the  user  must 
type: 

EMYCIN.EXE 

16.  The  EMYCIN.EXE  will  respond  with: 

LOADING  CHANGES  . . . 

FILE  CREATED  (date)  and  (time) 

CHANG ESCOMS 

(<DECAIDS>  CHANGES. .current  number) 

(<DECAIDS>  EMYCIN.EXE. 8. <DECAIDS>LISP. EXE. 80516) 

17.  The  "_"  is  the  EMYCIN  prompt  symbol  after  which 
DECAIDS  commands  may  be  issued. 

18.  To  begin  the  DECAIDS  consultation  program,  the  user 
enters  : 

BEGIN] 
The  right  square  bracket  must  be  entered.   A  short  delay 
CIO  to  30  seconds)  may  be  experienced  before  the  next  system 
response  occurs . 

19.  The  user  will  next  be  challenged  with: 

SPECIAL  OPTIONS  (TYPE  ?  for  HELP) 

20.  The  user  may  respond  with  a  carriage  return  if  no 
special  options,  such  as  fault  tracing  (i.e.,  FT  1  or  2  or 
3  or  4) ,  are  desired  or  with  a  "?"  if  an  explanation  of 
available  options  is  desired. 

21.  The  system  will  next  challenge  the  user  with: 

INSTRUCTIONS  (Y  or  N) 

22.  On  the  same  line  a  MY"  response  to  21  above  will 
present  a  line  of  instructions  on  the  use  of  the  DECAIDS 
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system  and  an  "N"  will  continue  with  the  DECAIDS  consultation 
session. 

23.  DECAIDS  will  continue  with  the  consultation  by 
presenting  the  user  with: 

(current  date)  and  (current  time) 

ORGANIZATIONS 

1)   THIS  PROGRAM  IS  DESIGNED  TO  PROVIDE 
MANAGERS  AT  ALL  LEVELS  WITH  ADVICE 
CONCERNING  THE  USE  OF  THEIR  COMPUTER 
RESOURCES.   IN  ORDER  TO  PROVIDE  THIS 
INFORMATION,  THE  USER  WILL  BE  ASKED  TO 
FURNISH  DATA  CONCERNING:   HIS  ORGANI- 
ZATION, ITS  LEVEL  OF  TRAINING,  THE 
ORGANIZATION'S  LEADER,  THE  ENVIRON- 
MENT AFFECTING  THE  DECISION,  AND  THE 
TASK  FACING  THE  ORGANIZATION.   WHAT 
IS  THE  TYPE  OF  PROBLEM  WHICH  THE 
ORGANIZATION  FACES? 

This  is  the  beginning  of  the  consultation  session.   This  first 

question  about  the  type  of  problem  may  be  answered  with  any 

subject  name,  for  example:   electronic  warfare.   A  full 

consultation  session  is  presented  in  Appendix  C. 

24.  The  consultation  will  continue  by  asking  ten 
additional  questions  for  the  user  to  answer  at  the  end  of 
which  the  user  will  be  presented  with  the  DECAIDS  recommen- 
dations . 

25.  After  the  recommendations  are  offered,  the  system 
will  ask: 

Do  you  wish  advice  on  another  patient? 
CBased  originally  on  a  medical  background,  the  inference 
engine  continues  to  ask  for  "patients.") 
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26.  A  user  response  of  MY"  will  start  another  consulta- 
tion session  with  a  title  of  ORGANIZATION- 2  and  an  "N" 
response  will  return  the  user  to  the  TOPS-20  operation  system 
and  its  prompt  of: 

§ 

27.  To  log  off  the  system  from  the  TOPS-20  operating 
system  the  user  need  only  enter: 

LOGO  carriage  return 

28.  The  system  will  respond  with: 

KILLED  JOB  (#),  USER  DECAIDS,  ACCOUNT  NPS-OTHER- 
STUDENTS,  TTY  167,  AT  (date,  USED  (time) 
CLOSED 
and  the  session  is  closed. 
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APPENDIX  G 
DECAIDS  KNOWLEDGE  BASE  MODIFICATION  PROCEDURES 

The  following  procedures  are  provided  as  a  quick 
reference  to  fill  in  a  new  knowledge  base  or  modify  an 
existing  one.   The  system  designer  will  be  required  to  declare 
parameters,  define  rules,  and  to  save  (make  a  file  called 
CHANGES)  the  declarations  and  definitions.   The  parameters 
declared  may  be  context  names ,  rule  group  names ,  or  value 
parameter  names.   The  EMCYIN  system  prompts  (requests  for 
values  from  the  designer)  for  the  types  of  parameters 
mentioned  above  will  be  summarized  in  this  section  and 
examples  will  be  provided.   A  carriage  return  is  to  be  typed 
after  each  sample  command.   Entering  the  EMYCIN  file  is 
accomplished  as  described  in  Appendix  F. 

A.   DECLARING  PARAMETERS 

1.  To  declare  parameters  the  designer  enters  the 
following  command  after  the  EMYCIN  prompt  of  "  " 

GETPARMS 

2.  The  system  will  respond  with: 
PARAMETER  NAME: 

3.  If  the  system  designer  then  responds  with  the  name 
of  a  new  parameter,  the  system  will  commence  prompting  for 
parameter  property  values. 

4.  The  first  prompt  for  a  property  value  will  be: 
PROPGROUP: 
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5.  A  response  to  PROPGROUP  of 

a.  ALLNAMES:   signals  the  system  that  the  parameter 
is  to  be  a  rulegroup  name 

b.  PROP-VAL  signals  that  the  parameter  is  to  be  a 
context  name,  and 

c.  PROP- (name)  signals  that  the  parameter  is  to  be  a 
value  parameter  in  the  parameter  grouping  of  (name) 
which  is  of  the  designer's  choosing. 

6.  RULE  GROUP  DECLARATIONS 

a.  If  the  parameter  is  to  be  a  rule  group,  then 
the  next  property  prompt  will  be 

CONTEXT? 

b.  The  designer  should  respond  with  the  context (s) 
names  to  which  the  rules  of  the  named  rule  group 
will  apply,  i.e.  : 

ORGANIZATION 

c.  The  next  property  prompt  will  be: 

SVAL : 

d.  The  designer  shall  respond  with  the  appropriate 
context  name,  i.e.: 

ORGANIZATION 

e.  The  following  prompt  will  be  for: 

CTRANS: 

f.  The  appropriate  context  name  is  the  correct 
designer  response,  i.e.: 

ORGANIZATION 
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g.   The  next  prompt  will  be  for: 

PROPTYPE : 
h.   Here,  the  designer  should  respond  with: 
PROP-ALLNAMES 
The  system  will  return  with  a  prompt  for: 

SUBPROPERTY : 
A  carriage  return  after  "SUBPROPERTY"  will 
return  a  system  response  of: 

PARAMETER  NAME: 
A  carriage  return  after  "PARAMETER  NAME"  will  take 
the  user  out  of  the  GETPARMS  subprogram  and  return 
a : 

DONE 
7.   CONTEXT  DECLARATIONS 

a.  If  the  response  to  PROPGROUP  is  PROP-VAL,  then  the 
first  prompt  for  a  context  parameter  will  be: 

TRANS : 

b.  The  designer  response  to  "TRANS:"  is  the 
designer's  literal  interpretation  of  his  intent 
for  this  context  name,  i.e.  : 

(the  organization) 

c.  The  next  property  prompt  is: 

MAINPROPS: 

d.  The  designer  response  may  be  a  carriage  return  if 
no  MAINPROPS  are  to  be  used  or  a  list  of  param- 
eter names ,  i.e.: 

(PROBTYPE  TASK  STRUCTURE  TECHNOLOGY) 
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e.  The  context  parameter's  next  property  prompt  will 
be: 

PROPTYPE : 

f.  The  designer  should  respond  to  PROPTYPE  with  the 
value  parameter  group (s)  names  to  which  this 
context  will  apply,  i.e.: 

PROP-ORG 

g.  The  next  property  prompt  will  be: 

TYPE: 
h.   The  correct  designer  response  to  "TYPE:"  is  the 
appropriate  context  name,  i.e.: 
ORGANIZATION 
i.   The  system  will  next  prompt  for  a  response  to: 

RULETYPES : 
j.   Here,  the  proper  response  is  the  rule  group (s) 
names  to  which  the  context  will  apply,  i.e.: 
(ORGRULES) 
k.   The  final  property  prompt  seen  in  context  declara^ 
tions  in  DECAIDS  is : 
GOALS : 
1.   The  designer  should  respond  with  those  goal- 
parameters  for  the  current  context,  i.e.: 
(DECAIDS  FORMAL  UNKSTRUC) 
m.   After  prompting  for  the  standard  property 

values  listed  above,  the  system  will  request: 
SUBPROPERTY: 
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n.   If  the  designer  has  a  need  to  use  additional 

property  values,  such  as  LABDATA,  then  he  should 
respond  to  "SUBPROPERTY :"  with  the  name  of  that 
property  which  he  should  use,  i.e.: 
LABDATA 
o.   The  system  will  then  prompt  the  designer  to  pro- 
vide a  value  for  the  subproperty  just  defined, 
i.e .  : 

LABDATA: 
p.   A  proper  response  to  "LABDATA:"  is: 

T 
q.   When  the  designer  has  completed  declaring  param- 
eters, a  carriage  return  should  be  entered  to  the 
systems  request  for  another  subproperty  defini- 
tion, 
r.   The  system  will  next  return  with: 
PARAMETER  NAME: 
A  carriage  return  response  here  will  cause  a 
system  response  of: 

DONE 
and  return  the  designer  to  the  EMYCIN.EXE  file 
with  its  "_"  prompt. 
8.   SAVING  FILES 

a.   The  above  work  is  saved  in  a  CHANGES  file  with  the 
following  command: 
MF  CHANGES 
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b.   The  EMYCIN  file  will  return  the  now  current 
edition  number  of  the  CHANGES  file. 
9.   CHANGING  A  PROPERTY  VALUE 

a.  Changes  to  a  property  value  are  made  by  typing  the 
property  name  while  still  in  the  GETPARMS  sub- 
program, i.e.: 

PARAMETER  NAME:   STRESS 
SUBPROPERTY:   TRANS 

b.  The  system  will  return  that  subproperty  to  the 
designer  expecting  a  new  value  to  be  entered,  i.e. 

TRANS: 

c.  The  designer  should  enter  a  new  value  and  a 
carriage  return,  i.e.: 

(THE  NEW  ORGANIZATION)    carriage  return 

d.  The  system  will  challenge  with 

[NEW  VALUE] 

e.  On  the  same  line  as  "[NEW  VALUE],"  the  designer 
must  respond  with: 

YES,  for  "YES"  or  N,  for  "NO" 

f.  The  system  will  then  continue  prompting  with: 

SUBPROPERTY: 

B.   DEFINING  RULES 

1.  Rules  are  defined  by  initiating  a  call  to  the 
GETRULES  subprogram  with: 

GETRULES] 

2.  The  system  will  respond  with: 
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RULE#,  NEW  or  SUBJECT  FOR  NEW  RULE: 

3.  To  enter  a  new  rule,  the  designer  must  respond  with: 

NEW 
To  edit  an  old  rule,  the  designer  must  respond  with  the 
desired  rule  number  to  be  edited. 

4.  After  "NEW"  is  typed  by  the  designer,  the  system  will 
respond  with: 

ANTECEDENT  RULE? 

5.  In  most  cases  the  rule  will  not  be  an  antecedent  rule 
and  the  correct  response  is  simply: 

N 

6.  The  system  next  sends: 

RULE  (number) 
PREMISE: 

7.  For  a  new  rule,  the  designer  should  first  define  a 
rule  premise  and  should  respond  to  6  above  with  his  premise 
statement,  in  the  INTERLISP  syntax,  i.e." 

($AND  (SAME  CNTXT  STRESS  LOW)) 

8.  The  systems  response  will  be  either: 

a.  an  error  message  for  syntax  or  undeclared 
parameter , 

or 

b.  RULE  (number) 
ACTION: 

9.  In  response  to  the  system's  request  for  the  ACTION 
statement,  the  designer  should  enter  the  rule's  appropriate 
action  statement,  i.e.: 
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(CONCLUDE  CNTXT  SIZE  LARGE  TALLY  900) 
The  "TALLY  900"  is  the  designer's  certainty  factor  entry. 

10.  The  system  may  again  respond  with  an  error  message  or 
return: 

SUBJECT  OF  RULE  (number)  IS  (rule  group  name) 
[CONFIRMf 

11.  If  (rule  group)  is  the  correct  name  to  which  the 
rule  belongs,  then  enter 

Y 
immediately  after  [CONFIRM],  i.e.: 
[CONFIRM]  Y 

12.  If  in  response  to  "RULE# ,  NEW  or  SUBJECT  FOR  NEW  RULE:, 
the  designer  enters  a  rule  number,  the  system  will  return: 

TRANSLATE,  DELETE,  NO  CHANGE,  OR  NAME 
OF  PROP  TO  MODIFY: 

13.  The  designer  may  now  specify  the  premise  or  action 
statement  if  he  chooses  to  edit  either,  i.e.: 

TRANSLATE,  DELETE,  NO  CHANGE,  OR  NAME  OR 
PROP  TO  MODIFY:   PREMISE 

14.  The  system  will  respond  with  the  current  premise  value 
and  on  the  next  line  return: 

PREMISE: 
awaiting  the  new  value. 

15.  After  the  new  value  has  been  entered,  the  system 
will  challenge  with: 

[NEW  VALUE] : 
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a  "Y"  for  "yes"  or  "N"  for  "no"  immediately  after  [NEW 
VALUE]  is  the  correct  response. 

16.  A  carriage  return  after  RULE#,  NEW  or... will  cause  the 
system  to  return: 

DONE 

17.  Rules  may  now  be  saved  with: 

MF  CHANGES 

18.  Debugging  of  error  messages  may  be  facilitated  by 
reference  to  the  XEROX  INTERLISP  Manual  and  via  communications 
with  the  AI  personnel  at  Stanford  University.   (ARPANET 
address : 

SCOTT@@@SUMEX-AIM 
Carlisle  Scott  is  a  programmer  with  the  AI  group  at  Stanford 
University  who  has  provided  a  great  deal  of  assistance  in 
learning  the  EMYCIN  system.) 

C.  PRINTING  PARAMETERS  AND  RULES 

1.  The  parameters  list  is  printed  out  with  the  follow- 
ing command: 

PRINTPARMS  (NIL  T  72  T) 

2.  The  rules  may  be  listed  with  the  following  command: 

(PRINTRULES  rulegroup  name  'B) 

D.  LOGGING  OFF  FROM  THE  DECAIDS  FULE 

1.   From  the  DECAIDS  file  a  CONTROL-C  command  and  no 
carriage  return  will  return  the  system  designer  or  consul- 
tation user  to  the  TOPS- 20  operating  system. 
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2.  The  command: 

LOGO 
will  log  the  system  user  off  of  the  computer  at  ISIE  and  off 
of  the  ARPANET  TIP. 

3.  The  system  will  terminate  with: 

KILLED  JOB  #,  USER  DECAIDS,  ACCOUNT  NPF- 
OTHER-STUDENTS,  TTY  135,  at  (date  time), 
USED  (time)  CLOSED. 
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